别使用 MySQL 的 SQL_CALC_FOUND_ROWS 来获取总行数

当我们在处理分页程序的时候,会使用 limit 来限制返回的数量,然后会有两种获取分页的方法:

第一种方法:

在 SELECT 语句中加入 SQL_CALC_FOUND_ROWS 选项,然后通过 SELECT FOUND_ROWS() 来获取总行数:

SELECT SQL_CALC_FOUND_ROWS * FROM table WHERE id > 100 LIMIT 10;
SELECT FOUND_ROWS();

其中的 SQL_CALC_FOUND_ROWS 语句会统计出符合筛选条件的记录总数,保存在mysql 端;

后面使用 SELECT FOUND_ROWS() 语句可以得到这个数字,不用再次计算。当然,如果你再次运行了SQL_CALC_FOUND_ROWS的话,这个数字就会被覆盖成最新的。

如果在前一条语句中没有使用SQL_CALC_FOUND_ROWS选项,SELECT FOUND_ROWS()将返回前一条语句实际返回的行数

注意

mysql会为当前连接保存这个值,各个连接的SQL_CALC_FOUND_ROWS结果互不影响

两条sql语句可以简化成一条sql语句,看似简单了,实则不然。

原因

1. 在有索引覆盖的情况下,SQL_CALC_FOUND_ROWS 和 COUNT(*)的效率差不多

2. 在没有索引覆盖的情况下,SQL_CALC_FOUND_ROWS的效率要远低于COUNT(*)的效率,大概只有COUNT(*)的十分之一,甚至更低

第二种方式:

使用正常的 SQL 语句,然后再用 SELECT COUNT(*) 来获取总行数:

SELECT * FROM table WHERE id > 100 LIMIT 10;
SELECT COUNT(*) FROM table WHERE id > 100;

经过测试,一般来说 SQL_CALC_FOUND_ROWS 是比较慢的,SQL执行的时间甚至会达到10倍那么夸张,所以最好别使用 MySQL 的 SQL_CALC_FOUND_ROWS 来获取总行数

记得尽量使用索引覆盖,这样count(索引列)可以使用到索引覆盖,效率很高。

posted @ 2022-12-16 14:28  培轩  阅读(196)  评论(0)    收藏  举报