如何在 MySQL 中使用 LIMIT 高效检索总行数?

DDD
发布: 2024-10-27 02:54:30
原创
860 人浏览过

 How to Efficiently Retrieve Total Row Count with LIMIT in MySQL?

使用 LIMIT 条件检索总行数

使用带有 LIMIT 子句的 SQL 查询进行分页时,确定总行数变为一个挑战。标准方法涉及执行查询两次,一次不使用 LIMIT 子句来获取行计数,然后再次使用 LIMIT 来检索分页数据。对于复杂的查询,此过程可能非常耗时。

但是,MySQL 4.0.0 中引入了更高效的解决方案:

使用 SQL_CALC_FOUND_ROWS 和 FOUND_ROWS()

SQL_CALC_FOUND_ROWS 选项可以添加到 SELECT 语句之后的查询中。这标记 MySQL 计算总行数而不考虑 LIMIT 条件。要检索总行数,需要使用 FOUND_ROWS() 函数进行第二次查询。

用法:

SELECT SQL_CALC_FOUND_ROWS name, email FROM users WHERE name LIKE 'a%' LIMIT 10;
SELECT FOUND_ROWS();
登录后复制

注意:在第一个查询之后立即执行第二个查询至关重要,因为 SQL_CALC_FOUND_ROWS 不会永久存储行计数。

弃用 SQL_CALC_FOUND_ROWS 和 FOUND_ROWS()

As从 MySQL 8.0.17 开始,SQL_CALC_FOUND_ROWS 查询修饰符和 FOUND_ROWS() 函数已被弃用,并将在未来的 MySQL 版本中删除。建议使用 COUNT 代替:

SELECT * FROM tbl_name WHERE id > 100 LIMIT 10;
SELECT COUNT(*) WHERE id > 100;
登录后复制

以上是如何在 MySQL 中使用 LIMIT 高效检索总行数?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!