• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Mysql解决mysql的分页场景下,页数越大查询速度越慢的方法

武飞扬头像
小丛的知识窝
帮助1

一 问题描述
select * from table limit 0,10扫描满足条件的10行,返回10行,
但当limit 99989,10的时候数据读取就很慢,limit 99989,10的意思扫描满足条件的99999行,扔掉前面的99989行,返回最后的10行,这样速度就会很慢了。
二 解决方案
利用表的覆盖索引来加速分页查询,使用索引查询的sql语句中如果select的字段只包含索引列(覆盖索引),那么这种情况查询速度就会很快。
举个例子:
当id字段是主键,在部分数据库引擎中会创建主键索引。

select id from table limit 99989,10;

会发现查询结果很快。
通过这个查询中返回的id,再次查询对应id(因为又主键索引也会很快).

select * from table where id >= (select id from product limit 99989,1) limit 10;
select * from table where id in (select id from product limit 99989,10);
select * from table t join (select id from table limit 99989,10) t1 on t.ID=t1.id;

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhggceeg
系列文章
更多 icon
同类精品
更多 icon
继续加载