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

 更新时间:2025年12月16日 11:22:32   作者:kkkkkkkkl24  
文章总结了在企业级项目中优化深分页查询的经验,包括执行计划分析、索引优化和游标分页改写,通过复合索引和游标分页,可以显著提高查询性能,感兴趣的朋友跟随小编一起看看吧

在企业级项目中,深分页查询经常会成为性能瓶颈。本篇文章总结了我在实践中优化深分页 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

分析:

  • type=ref → 使用了 user_id 索引进行精确匹配。
  • key=user_id → 索引选择正确。
  • Extra=Using filesort → ORDER BY create_time DESC 未覆盖索引,需要额外排序。
  • 扫描行数 → MySQL 会扫描前 990 条行再丢弃(LIMIT 偏移量大),深分页效率低。

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

三、复合索引优化

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

ALTER TABLE orders ADD INDEX idx_user_create (user_id, create_time DESC);
  • 作用
    • 覆盖 WHERE user_id=… 条件。
    • 覆盖 ORDER BY create_time DESC 条件。
  • 优化后 EXPLAIN
idselect_typetabletypepossible_keyskeykey_lenrowsExtra
1SIMPLEordersrefidx_user_createidx_user_create820Using index condition

分析:

  • type=ref → ref → 使用索引范围扫描,避免全表扫描。
  • key_len=8 → 复合索引长度增加。
  • 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

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

五、实践总结

  • 深分页性能问题
    • OFFSET 大时,MySQL 会扫描并丢弃大量行。
    • ORDER BY 未覆盖索引 → filesort
  • 优化策略
  • 复合索引覆盖 WHERE + ORDER BY
  • 游标分页替代大 OFFSET 分页。
  • EXPLAIN 解析技巧
  • type → 尽量是 refrangeconst,避免 ALL
  • key / key_len → 关注索引是否被正确使用。
  • Extra → 理解 Using index conditionUsing filesort
  • 经验总结
    • 使用 ICP 能减少回表行数。
    • 游标分页适合大数据量分页查询。
    • SQL 优化不仅是索引,改写查询逻辑同样重要。

到此这篇关于MySQL 深分页查询优化实践与经验分享的文章就介绍到这了,更多相关mysql深分页查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql中的自连接问题

    Mysql中的自连接问题

    这篇文章主要介绍了Mysql中的自连接问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • Windows下使用Cygwin编译MySQL客户端

    Windows下使用Cygwin编译MySQL客户端

    这篇文章主要介绍了Windows下使用Cygwin编译MySQL客户端,本文详细的讲解了编译过程,需要的朋友可以参考下
    2015-04-04
  • 达梦数据库兼容mysql GROUP BY查询的设置方式

    达梦数据库兼容mysql GROUP BY查询的设置方式

    作为一名数据库管理员或开发者,当项目需要从MySQL迁移到达梦数据库时,最关心的莫过于兼容性问题,这篇文章主要介绍了达梦数据库兼容mysql GROUP BY查询的设置方式,需要的朋友可以参考下
    2025-11-11
  • mysql序号rownum行号实现方式

    mysql序号rownum行号实现方式

    这篇文章主要介绍了mysql序号rownum行号实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • MYSQL存储过程即常用逻辑知识点总结

    MYSQL存储过程即常用逻辑知识点总结

    在本篇文章里小编给大家整理的是关于MYSQL存储过程即常用逻辑知识点,有需要的朋友们可以学习下。
    2019-08-08
  • 利用Mysql定时+存储过程创建临时表统计数据的过程

    利用Mysql定时+存储过程创建临时表统计数据的过程

    这篇文章主要介绍了利用Mysql定时+存储过程创建临时表统计数据,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • MySQL 数据库空间使用大小查询的方法实现

    MySQL 数据库空间使用大小查询的方法实现

    本文主要介绍了MySQL 数据库空间使用大小查询的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-07-07
  • 查询优化之EXPLAIN的使用分析

    查询优化之EXPLAIN的使用分析

    本篇文章是对EXPLAIN的使用进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • MySQL操作数据库和表的常用命令新手教程

    MySQL操作数据库和表的常用命令新手教程

    这篇文章主要介绍了MySQL操作数据库和表的常用命令新手教程,本文总结的命令都是控制mysql必须掌握的、常用的命令,需要的朋友可以参考下
    2014-09-09
  • MySQL数据备份、还原、数据库迁移以及表的导出和导入

    MySQL数据备份、还原、数据库迁移以及表的导出和导入

    作为流行的开源数据库管理系统,MySQL的使用者众多,为了维护数据安全性,数据备份是必不可少的,下面这篇文章主要给大家介绍了关于MySQL数据备份、还原、数据库迁移以及表的导出和导入的相关资料,需要的朋友可以参考下
    2022-11-11

最新评论