百度 | 神马 | 搜狗 | 技术文档 | 学习资料分享 - 记录帝国CMS及运维技术的点点滴滴
你的位置:首页 > 实用IT技术 » 正文

【Wordpress相关】别使用 MySQL 的 SQL_CALC_FOUND_ROWS 来获取总行数

发布时间:2020-09-17

别使用 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();

第二种方式:

<script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script>

使用正常的 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 来获取总行数


本站推荐使用的主机:,国外主机建议使用

Top