首页 >数据库 >mysql教程 >即使在 SQL 中使用 LIMIT 分页,如何检索总行数?

即使在 SQL 中使用 LIMIT 分页,如何检索总行数?

Susan Sarandon
Susan Sarandon原创
2024-10-27 15:29:01908浏览

How do you retrieve the total number of rows even when using pagination with LIMIT in SQL?

即使在使用 LIMIT 分页时也检索总行

在 SQL 中使用 LIMIT 子句对结果进行分页时,必须运行两次查询才能获取结果可能会很麻烦总行数。对于需要大量时间执行的复杂查询尤其如此。幸运的是,有一个解决方案允许您通过单个查询来完成此操作。

SQL_CALC_FOUND_ROWS 和 FOUND_ROWS()

从 MySQL 4.0.0 开始,您可以在主查询中使用 SQL_CALC_FOUND_ROWS 选项通知 MySQL 计算总行数,同时忽略 LIMIT 子句。这需要您执行第二个查询来检索行计数。但是,此查询通常比主数据检索查询更简单、更快。

使用方法如下:

<code class="sql">SELECT SQL_CALC_FOUND_ROWS name, email FROM users WHERE name LIKE 'a%' LIMIT 10;
SELECT FOUND_ROWS();</code>

紧随第一个查询之后的第二个查询捕获总行使用 FOUND_ROWS() 函数进行计数。

在 MySQL 8.0 中已弃用

在 MySQL 版本 8.0.17 及更高版本中,SQL_CALC_FOUND_ROWS 修饰符和 FOUND_ROWS() 函数已被弃用,并将在未来的版本。 MySQL 文档现在建议使用 COUNT 来获取总行数。

例如:

<code class="sql">SELECT * FROM tbl_name WHERE id > 100 LIMIT 10;
SELECT COUNT(*) WHERE id > 100;</code>

结论

通过利用这些技术,您可以有效地检索即使使用带有 LIMIT 子句的分页,也能显示总行数,从而提高查询效率并简化代码。

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

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn