优化分页的查询

Posted 心碎whn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了优化分页的查询相关的知识,希望对你有一定的参考价值。

一般分页查询时,通过创建覆盖索引能够比较好的提高性能。一个经常使用的场景:"limit 1000,20",此时mysql排序出前1020记录后仅仅返回第1001到1020条记录。前1000条记录会被抛弃,查询和排序的代价非常高。

 

第一种优化思路

在索引上完成排序分页的操作,最后根据主键关联回原表查询所需要的其他列内容。尽可能扫描少的页面来提高分页的效率。

 

 explain select film_id,description from film order by title limit 50,5\\G;

从输出的结果看:优化器做了全表扫描,处理效率不高。

 

 优化

explain select a.film_id,a.description from film a inner join(select film_id from film order by title limit 50,5)b on a.film_id = b.film_id\\G;

 

 

第二种优化思路

把limit查询转换成某个位置的查询。如: 第n的最后一条的id为1100,现在需要翻页到n+1页,可以通过前台传入第n页的最后一条记录的id为1100。

 

 

以上是关于优化分页的查询的主要内容,如果未能解决你的问题,请参考以下文章

mysql使用limit分页优化方案

sql分页优化

jqgrid分页后,自定义查询数据怎么得到所有页的某列值的合计

如何优化Mysql千万级快速分页

postgres limit 分页的坑

mysql百万数据分页查询4秒,求教怎么优化