limit (page-1)*page_size,page_size
而当这语句分页到一定程度时,例如1000页,每页20条
select * from a limit 19980,20
会发现分页之后查询的会越来越慢...原因是因为limit a,b 的取数据方式是,先取出a+b条数据,再把a条筛选掉,剩b条,相当于一次性要取a+b条的数据,而a条其实是无用的
解决方案如下
一:php代码解决
例如我们先查询出第一页的数据...:
select * from a limit 20
保留最后一个的id,当需要取第2页数据时,则
select * from a where id>最后一个的id limit 20
这样数据库就会每次都能走索引...,然后才从索引里关联取出20条记录,大大的提升了查询速度
实例图:
?...普通方法查询,0.123秒
上一页最后一个的id为20000,则
?
php方法查询,0.070秒
?
mysql索引覆盖查询,0.089秒