美文网首页Java
MySQL的SQL_CALC_FOUND_ROWS

MySQL的SQL_CALC_FOUND_ROWS

作者: f6f54c35b57a | 来源:发表于2016-09-20 10:17 被阅读27次

分页程序一般由两条SQL组成:

SELECT COUNT(*) FROM ... WHERE ....
SELECT ... FROM ... WHERE LIMIT ...

如果使用SQL_CALC_FOUND_ROWS的话,一条SQL就可以了:

SELECT SQL_CALC_FOUND_ROWS ... FROM ... WHERE LIMIT ...

在得到数据后,通过FOUND_ROWS()可以得到不带LIMIT的结果数:

SELECT FOUND_ROWS()

这个方法有一个副作用,当使用了SQL_CALC_FOUND_ROWS以后,将不能使用查询缓存、在特殊情况下反而或损失一些性能。
例如,一个文章表,所有文章做了主键ID,并做了CREATE_TIME DESC的索引。这样在执行

SELECT * FROM ARTICLE ORDER BY ID DESC LIMIT 10 或者 CREATE_TIME DESC LIMIT 20 时,数据库引擎可以完全根据索引返回最新文章而不会管你有多少符合的记录,但用了SQL_CALC_FOUND_ROWS后引擎不得不扫描全表以确定全部记录数。

但无论怎样,这个 SQL_CALC_FOUND_ROWS 非常适合where字句异常复杂耗时的情况。在频繁使用查询的应用中,这个方法能够带来1/3的数据库性能提升。

相关文章

网友评论

    本文标题:MySQL的SQL_CALC_FOUND_ROWS

    本文链接:https://www.haomeiwen.com/subject/atxoettx.html