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

 

已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页