通过分页确定总行数
在 SQL 查询中实现分页时,准确确定总行数至关重要。运行查询两次(一次不使用 LIMIT 子句来计算行数,一次使用 LIMIT 子句来检索分页数据)可能不是最佳选择,特别是对于复杂查询。
幸运的是,MySQL 提供了一个优雅的解决方案: SQL_CALC_FOUND_ROWS 和 FOUND_ROWS() 构造。通过将 SQL_CALC_FOUND_ROWS 添加到主查询,即使存在 LIMIT 子句,MySQL 也会计算总行数。使用 FOUND_ROWS() 的后续查询将检索此计数。
下面是一个示例:
SELECT SQL_CALC_FOUND_ROWS name, email FROM users WHERE name LIKE 'a%' LIMIT 10; SELECT FOUND_ROWS();
此方法比运行查询两次更快,并提供准确的总计数。
MySQL 8 中已弃用的函数
在 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;
通过利用这些技术,开发人员可以准确计算分页 SQL 查询中的行数,而无需多个查询的开销。
以上是如何有效地确定分页 SQL 查询中的总行数?的详细内容。更多信息请关注PHP中文网其他相关文章!