Mysq limit深度分页解决方案

有个机构基本信息表,数据量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
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值