SQL_CALC_FOUND_ROWS的用法

我们在分页程序中往往这样写

SELECT COUNT(*) from `table` WHERE xxxxxx;  // 查出符合条件的记录总数
SELECT * FROM `table` WHERE xxxxxx limit M,N; // 查询当页要显示的数据

这种先统计总数,再统计分页的做法可以替换为下面的写法

SELECT SQL_CALC_FOUND_ROWS * FROM `table` WHERE xxxxxx  limit M, N; // 获取指定页的数据,且统计总条数

其中的 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_CALC_FOUND_ROWS来获取总数

建议使用COUNT(*)来统计总数后,保存在本地

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值