Mysq limit深度分页的简单解决方案

Mysql 专栏收录该内容
20 篇文章 0 订阅

有个机构基本信息表,数据量200多万,使用select * from org_basic_info limit 2016582,100查询耗时10s,表结构如下:

普通的limit m,n,m表示偏移量,n表示返回条数,当m偏移量很大时,就需要扫描过多的表数据,例如limit 1000000,100,查询就需要扫描1000100条,然后舍弃掉不符合条件的前1000000条,效率自然也就低了。考虑以下两种方式:

1、基于自增主键进行优化

select * from org_basic_info where org_uni_code > 2462028 limit 100

2、使用覆盖索引进行查询

select * from (select org_uni_code from org_basic_info limit 2016582,100)a 
left join org_basic_info b on a.org_uni_code=b.org_uni_code

 

  • 1
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

打赏
文章很值,打赏犒劳作者一下
相关推荐
©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页

打赏

饭一碗

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值