mysql分页查询的优化

优化LIMIT分页

在系统中需要进行分页才做的时候,我们通常会使用LIMIT加上偏移量的办法实现。
比如:

explain select * from orders limit 10 offset 10 ;

一个非常常见又令人头疼的问题就是,在偏移量非常大的时候(翻页到非常靠后的页面),例如可能是LIMIT 10000,10这样的查询,这时MySQL需要查询10020条记录然后只返回最后20条,前面10000条记录都被抛弃,这样的代价非常高。

那么如何优化这类查询呢?

第一步

首先对于这个查询select id from orders;我们可以explain一下

explain select id from orders;

会发现这是一个索引扫描(在存在辅助索引的情况下),相对表扫描这
个是会快很多的

第二步

基与上面的理论那么先将需要的id取出来 然后做一个子查询

select * from orders WHERE id >= (select id from orders order by id limit 1 offset 10000) limit 10;

不过这个查询是基于ID自增的假设,如果ID不是自增, 那么可以通过INNER JOIN 来改写

select * from  orders INNER JOIN (select id from orders order by id LIMIT 10 offset 10000) t  USING (id);

补充

  • 分页的显示

    • 如果有获取数据总数 那么通过总数自然可以得到页数
      一般获取数据总数是一个索引扫描,如果数据量很大在innodb下对于sql什么优化的有段
    • 如果没有总数 那么获取的时候多获取一些数据, 比如每页20个 我获取21个 如果能取到自然有下一页
  • 还是很慢怎么解决

    • 从业务考虑 是否真的需要这种翻页, 因为普通用户的话很少会关心历史数据
    • 可以考虑按时间段分表
    • 维护一根分页表,这样直接就可以获得某也有多少数据
    • 交给其他工具去做,不让mysql做自己不擅长的事情

总结

优化此类分页查询的一个最简单的办法就是尽可能地使用索引覆盖查询,而不是查询所有的列。然后根据需要做一个关联操作再返回所需的列。对于偏移量很大的时候,这样做的效率会提升很大。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 国庆第二天,今天嗨翻模式的开启就等室友的同学来了再说吧,在这之前,先来一波笔记 查询真正重要的是响应时间,查询包含...
    小炼君阅读 1,760评论 0 50
  • 学习自: 数据库开发 很多应用往往只展示最新或最热门的几条记录,但为了旧记录仍然可访问,所以就需要个分页的导航栏。...
    wyatt_plus阅读 520评论 1 2
  • 在mysql中limit可以实现快速分页,但是如果数据到了几百万时我们的limit必须优化才能有效的合理的实现分页...
    bycall阅读 4,060评论 0 5
  • “真的,还是姑娘你,做的饭好吃。” 哈哈哈哈,吃到一半居然还噎住了,哪有你说的那么好吃啊,我天天吃自己做的饭都要吃...
    流荆望楚阅读 210评论 0 1
  • 我现在很烦躁,这种感觉我已经很久没有拥有过了,就像在我的心中有一只蚂蚁,它寻不到出路,只能毫无章序的乱爬。...
    八宝_阅读 314评论 0 2