当前位置: 首页 > web >正文

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

一 问题描述

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;

原文地址 感谢大佬的分享 @小丛的知识窝

http://www.xdnf.cn/news/12542.html

相关文章:

  • K-Means颜色变卦和渐变色
  • linux系统终端远程控制和传输方式
  • 【 *p取出内容 a得到地址】
  • clickhouse 学习总结
  • KuiperInfer跟学第二课——张量的构建与实现
  • 什么是质量管理系统?质量管理系统都有哪些功能?
  • 5G网络中频段的分配
  • 无公网IP外网可访问项目研发管理软件 codes
  • AI界的“专家会诊”:MoE模型如何让AI变得更聪明?
  • Java多态机制深度解析
  • 在网页加载时自动运行js的方法(2025最新)
  • Linux 前后端项目问题排查命令手册
  • 量化面试绿皮书:5. 扑克牌游戏概率与期望值
  • 深入理解Java单例模式:确保类只有一个实例
  • android app 一个 crash的解决过程!
  • count() + case when统计问题
  • Next.js+prisma开发二
  • 【LLMs篇】14:扩散语言模型的理论优势与局限性
  • H_Prj06 8088单板机的串口
  • 贝叶斯网络_TomatoSCI分析日记
  • vanna+deepseek+chainlit 实现自然语言转SQL的精度调优
  • 一种全新的非对称加密算法
  • 豪斯多夫距离 (Hausdorff Distance)在机器人轨迹规划中的应用
  • Kubernetes指标实现有效的集群监控和优化
  • 免费批量图片格式转换工具
  • usbutils工具的使用帮助
  • 【时时三省】(C语言基础)局部变量和全局变量
  • CSDN文章下载到本地的完整指南
  • 88.实现查看收藏功能的前端实现
  • 43道Java多线程高频题整理(附答案背诵版)