使用分页(“LIMIT”子句)执行复杂的 MySQL 查询时,获取总行数可能具有挑战性。运行查询两次,其中一次没有总计数的 LIMIT 子句,效率可能会很低。
幸运的是,MySQL 引入了 SQL_CALC_FOUND_ROWS 选项,它允许您在仍然使用 LIMIT 子句的同时计算总行数。其工作原理如下:
示例查询:
<code class="sql">-- Main query with SQL_CALC_FOUND_ROWS SELECT SQL_CALC_FOUND_ROWS name, email FROM users WHERE name LIKE 'a%' LIMIT 10; -- Second query to get row count SELECT FOUND_ROWS();</code>
限制和替代方案:
虽然 SQL_CALC_FOUND_ROWS 提供了一个方便的解决方案,但请注意,它的用法在 MySQL 8.0.17 中已弃用。在大多数情况下,运行查询两次仍然更快。
作为替代方案,MySQL 8.0 引入了以下用于获取行数的优化选项:
通过利用这些技术,开发人员可以有效地检索分页 MySQL 查询中的总行数,而不会影响速度或性能。
以上是如何使用 SQL_CALC_FOUND_ROWS 高效获取分页 MySQL 查询中的行数?的详细内容。更多信息请关注PHP中文网其他相关文章!