news 2026/1/12 11:16:34

MySQL 深分页查询优化实践与经验总结

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL 深分页查询优化实践与经验总结

在企业级项目中,深分页查询经常会成为性能瓶颈。本篇文章总结了我在实践中优化深分页 SQL 的经验,包括执行计划分析、索引优化、游标分页改写等内容。


一、问题场景

假设我们有一张订单表orders,包含字段:

id, user_id, status, total_amount, create_time

原始查询为:

SELECT id, user_id, status, total_amount, create_time FROM orders WHERE user_id = 12345 ORDER BY create_time DESC LIMIT 990, 10;
  • 业务背景:查询某用户最近的订单,且需要支持分页。

  • 数据量假设:企业级通常几十万到几百万条订单。


二、原始 SQL 执行计划分析

使用 EXPLAIN查看原始 SQL:

idselect_typetabletypepossible_keyskeykey_lenrowsExtra
1SIMPLEordersrefuser_iduser_id450Using filesort

分析:

  1. type=ref→ 使用了user_id索引进行精确匹配。

  2. key=user_id→ 索引选择正确。

  3. Extra=Using filesort→ ORDER BY create_time DESC 未覆盖索引,需要额外排序。

  4. 扫描行数→ MySQL 会扫描前 990 条行再丢弃(LIMIT 偏移量大),深分页效率低。

✅ 结论:单列索引只能加速 WHERE 条件,排序仍需额外操作。


三、复合索引优化

为了提升查询效率,我们创建复合索引:

ALTER TABLE orders ADD INDEX idx_user_create (user_id, create_time DESC);
  • 作用

    1. 覆盖WHERE user_id=…条件。

    2. 覆盖ORDER BY create_time DESC条件。

  • 优化后 EXPLAIN

idselect_typetabletypepossible_keyskeykey_lenrowsExtra
1SIMPLEordersrefidx_user_createidx_user_create820Using index condition

分析:

  1. type=ref → ref→ 使用索引范围扫描,避免全表扫描。

  2. key_len=8→ 复合索引长度增加。

  3. Extra=Using index condition→ ICP (Index Condition Pushdown) 优化回表行数。

✅ 结论:复合索引同时覆盖 WHERE + ORDER BY,大幅减少扫描行数和排序成本。


四、游标分页改写

深分页仍有偏移量大的问题,可以改写为游标分页:

SELECT id, user_id, status, total_amount, create_time FROM orders WHERE user_id = 12345 AND create_time < '2024-06-01 12:00:00' ORDER BY create_time DESC LIMIT 10;
  • 优势

    • 不用 OFFSET,避免扫描前面大量行。

    • 对大数据量分页性能稳定。

  • EXPLAIN 输出

idselect_typetabletypepossible_keyskeykey_lenrowsExtra
1SIMPLEordersrangeidx_user_createidx_user_create810Using index condition

✅ 结论:扫描行数恒定,排序在索引中完成,性能最佳。


五、实践总结

  1. 深分页性能问题

    • OFFSET 大时,MySQL 会扫描并丢弃大量行。

    • ORDER BY 未覆盖索引 →filesort

  2. 优化策略

    • 复合索引覆盖 WHERE + ORDER BY

    • 游标分页替代大 OFFSET 分页。

  3. EXPLAIN 解析技巧

    • type→ 尽量是refrangeconst,避免ALL

    • key / key_len→ 关注索引是否被正确使用。

    • Extra→ 理解Using index conditionUsing filesort

  4. 经验总结

    • 使用 ICP 能减少回表行数。

    • 游标分页适合大数据量分页查询。

    • SQL 优化不仅是索引,改写查询逻辑同样重要。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/12 10:14:51

227827827

82872782

作者头像 李华
网站建设 2026/1/8 5:31:29

MCU的启动流程你了解么?

MCU&#xff08;微控制器单元&#xff09;的上电过程是一个精心设计的序列&#xff0c;它确保芯片从完全断电状态可靠地进入正常工作状态。1. 上电复位&#xff08;Power-on Reset&#xff09;当给MCU上电时&#xff0c;电源电压从0V开始上升至额定工作电压&#xff08;如3.3V&…

作者头像 李华
网站建设 2026/1/10 14:47:36

逻辑回归(Logistic Regression)进行多分类的实战

一、多分类策略 逻辑回归处理多分类主要有三种策略&#xff1a; OvR&#xff08;One-vs-Rest&#xff09; 为每个类别训练一个二分类器 预测时选择概率最高的类别 Scikit-learn默认使用此方法 OvO&#xff08;One-vs-One&#xff09; 为每对类别训练一个分类器 适合类别较少但样…

作者头像 李华
网站建设 2026/1/9 16:48:09

RNN(循环神经网络)原理

一、RNN基本思想与核心概念 1.1 为什么需要RNN&#xff1f; 传统神经网络&#xff08;如全连接网络、CNN&#xff09;无法处理序列数据&#xff0c;因为它们&#xff1a; 无记忆性&#xff1a;每个输入独立处理&#xff0c;忽略序列中元素的时间/顺序关系 固定输入尺寸&#xf…

作者头像 李华
网站建设 2026/1/10 15:44:22

人机协同重构创作生态——生成式AI赋能内容产业的变革与思考

当内容生产遭遇“产能焦虑”与“创意枯竭”的双重困境&#xff0c;生成式AI正以不可逆转的态势重构行业规则。2025年一季度数据显示&#xff0c;国内72%的内容团队已将AI工具纳入核心工作流&#xff0c;电商文案、短视频脚本等场景的AI渗透率超85%。这场变革不仅是生产效率的提…

作者头像 李华