xiaoxiaoshutong

问题描述:通常情况下MySQL数据库表查询通过limit关键字进行分页,当数据量不多时,能够非常快速返回数据据,但当数据达到百万级别是,当前页数字越大响应时间越长。

举个例子:用户表 200w 数据   

select * from t_user limit 0,20

  这是没有问题的,数据很快返回  

select * from t_user limit 1000080,20

上面这条语句返回比较慢。

原因:limit 0,20 仅扫描了20条数据,就返回结果,而 limit 1000080,20 扫描了1000080条数据,并去掉前面1000080条,返回剩下的20条数据。

解决方案1:记录上一次的最大maxId=1000079, 那么语句可以优化为:
select * from t_user where id>1000079 order by id limit 20

扫描20行。

总结:   当一个数据库表过于庞大,LIMIT offset, length中的offset值过大,则SQL查询语句会非常缓慢,你需增加order by,并且order by字段需要建立索引

解决方案2:如果limit的offset值过大,设置一个offset最大的,超过了可以另行处理,如:当偏移超过一半记录数的时候,先用排序,这样偏移就反转了。
解决方案3:>limit限制优化法把limit偏移量设置一个最大值。。超过这个数不查询数据库,直接返回空数据。

分类:

技术点:

相关文章:

  • 2021-12-09
  • 2021-06-02
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-08-28
  • 2022-01-13
  • 2021-08-31
猜你喜欢
  • 2021-11-25
  • 2021-11-26
  • 2021-08-05
  • 2021-08-05
  • 2022-12-23
相关资源
相似解决方案