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