SQL_CALC_FOUND_ROWS是指在执行带LIMIT的查询时,附带统计一下如果不加LIMIT的话将会输出多少条结果。
eg:
SELECT SQL_CALC_FOUND_ROWS * FROM `table_a` LEFT JOIN `table_b` on `table_a`.id = `table_b`.a_id GROUP BY `table_a`.id ORDER BY `ctime` desc limit 0,10;
查询完毕后再执行:
SELECT FOUND_ROWS();
这个语句返回group by 后的总记录数
显示
-------------|
FOUND_ROWS() |
-------------|
1000 |
-------------|
FOUND_ROWS()得到的数字是临时的,执行下一条语句就会失效,需要保存在一个变量中.
在很多分页的程序中都这样写:
SELECT COUNT(*) from `data_table` WHERE ......; 查出符合条件的记录总数
SELECT * FROM `data_table` WHERE ...... limit M,N; 查询当页要显示的数据
没有进行测试,需要比较COUNT 和 SQL_CALC_FOUND_ROWS 较耗时的需要自测
本文详细介绍了SQL_CALC_FOUND_ROWS的功能及使用场景,特别是在分页查询中的应用。通过具体示例展示了如何统计带LIMIT条件的查询结果总数,并对比了COUNT(*)的方法。
631

被折叠的 条评论
为什么被折叠?



