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

EXPLAIN执行计划深度解读:从type到cost,彻底读懂SQL为什么慢

关键词​:EXPLAIN;执行计划;type;rows;Extra;filtered;代价模型;EXPLAIN ANALYZE


大家好,我是小耶。上周讲了EXPLAIN的3个必看字段,评论区不少朋友说“够用但还想深入”。今天就把它彻底拆开,讲讲key_len怎么判断用了索引的哪几列,filtered如何评估回表代价,以及MySQL 8.0的EXPLAIN ANALYZE为什么比传统EXPLAIN更准。

1 问题背景:为什么只靠type还不够?

在日常优化中,typeALL变成rangeref固然能大幅提升性能,但当多个索引可选时,优化器的选择是否正确?索引用了但扫描行数依然很大怎么办?这些仅靠传统EXPLAIN难以回答。

MySQL 8.0引入了EXPLAIN ANALYZE,可以输出实际执行的成本和时间;FORMAT=JSON则能展示优化器的代价估算。掌握这些,才能真正理解SQL慢在哪里。

2 核心概念:EXPLAIN输出列详解

以下列是按重要性排序的必看项:

  • type​:访问类型。从优到劣:system>const>eq_ref>ref>range>index>ALLALL代表全表扫描,必须优化。

  • possible_keys​:可能用到的索引。若为NULL,说明无可用的索引。

  • key​:实际使用的索引。若为NULL,代表未走索引。

  • key_len​:实际使用的索引字节数。可推算索引中具体用了哪几列(例如utf8mb4每字符4字节,key_len=4表示只用了第一列)。

  • rows​:预估需要扫描的行数。数字越大越慢。但此为估算值,与filtered配合可估算回表行数。

  • filtered​:存储引擎层返回的数据经过WHERE条件过滤后剩余的比例。例如rows=1000filtered=10.00,表示最终大约返回100行。如果filtered很低且索引不包含所有WHERE列,说明需要回表过滤大量数据,可考虑覆盖索引。

  • Extra​:附加信息。常见的有:

    • Using index:覆盖索引,不回表,好。
    • Using index condition:索引下推,较好。
    • Using where:需要回表过滤,通常正常。
    • Using filesort:需要额外排序,应优化。
    • Using temporary:使用临时表,应优化。
  • EXPLAIN ANALYZE​(MySQL 8.0.18+):实际执行查询并输出每个步骤的实际耗时、循环次数、返回行数等,比估算准确。格式示例:
    text

    -> Nested loop inner join (actual time=0.1..0.2 rows=10 loops=1)

    注意:它会真实执行,生产环境慎用。

3 案例解析:从执行计划定位一个真实慢查询

3.1 问题SQL

SELECT * FROM orders WHERE user_id = 123 ORDER BY order_date DESC;

原索引为(user_id)EXPLAIN结果:

typekeyrowsExtra
refidx_user_id5000Using filesort

rows=5000(该用户有5000条订单),Extra=Using filesort(因为order_date没有索引,需要额外排序)。经验证该查询耗时0.8秒。

3.2 优化过程

添加联合索引(user_id, order_date)后:

typekeyrowsExtra
refidx_user_date5000(空)

无需filesort,耗时降至0.05秒。这里rows仍为5000,但Extra已无排序,且key_len可判断实际用了两列。

若需进一步优化,可改为覆盖索引(user_id, order_date, status, amount)避免回表,Extra会显示Using index

3.3 使用FORMAT=JSON查看代价

EXPLAIN FORMAT=JSON SELECT ...;

输出中的cost_info块展示了read_costeval_costprefix_cost,可比较不同索引的代价估算,帮助理解优化器决策。

4 总结与建议

  • 日常慢查询分析,先看typerows;若type不是ALLrows很大,检查filteredkey_lenExtra中出现Using filesortUsing temporary几乎总是需要优化。
  • MySQL 8.0用户可将EXPLAIN ANALYZE用于测试环境,获取真实执行成本。
  • 掌握这些,就不只是“能看懂”,而是能根据执行计划精准加索引或改写SQL。

理解执行计划是SQL调优的基石。从3个字段到全解读,你的优化能力会上一个台阶。

小耶在手,SQL 不愁。

还有什么想了解的,欢迎留言!小耶一定知无不言言无不尽……我们下次见~


参考文献

[1] MySQL官方文档:EXPLAIN Output Format
[2] MySQL 8.0 Reference Manual: EXPLAIN ANALYZE
[3] 《高性能MySQL》第4版,第9章“查询优化”

http://www.jsqmd.com/news/819823/

相关文章:

  • PlotAI:用自然语言生成数据可视化图表,解放数据分析生产力
  • 终极B站直播自由:如何绕开官方限制,用专业软件打造高质量直播体验
  • AI项目开发利器:ai-workspace-template全解析与实战指南
  • Adams几何元素:从基础构造到仿真建模的实用指南
  • 告别‘Connection refused’:保姆级教程教你用中科大镜像源5分钟搞定Mac HomeBrew安装
  • AI编程助手能力扩展:基于MCP协议为Cursor打造项目感知与工具调用能力
  • 【沐风老师】3dMax Gyroid极小曲面:从单元到无限阵列的实战建模指南
  • 2026年评价高的木床/省空间木床/佛山简约实木床实力工厂推荐 - 品牌宣传支持者
  • Hitboxer:解决游戏按键冲突的专业SOCD重映射工具
  • STM32 ADC采集NTC温度,如何优化精度与响应速度?从硬件选型到软件滤波全解析
  • Obsidian Weaver插件:自动化网页内容抓取与知识库结构化整合指南
  • 半导体硅测试与良率分析关键技术解析
  • 木质防火门基础选购核心要点
  • 2026年口碑好的呼市装修资质代办/呼市市政资质代办/呼市消防资质代办热门公司推荐 - 品牌宣传支持者
  • 分布式智能体系统确定性控制协议(DACP)设计原理与实践
  • 2026年靠谱的小户型原创沙发/真皮沙发优质厂家汇总推荐 - 行业平台推荐
  • 深度学习在侧信道分析中的泄漏定位技术
  • 5分钟快速上手VideoDownloadHelper:免费开源Chrome视频下载插件完整指南
  • 基于Godot Engine的3D树形结构可视化:从原理到实践
  • ARM PrimeCell SSP驱动架构与优化实践
  • 3分钟掌握百度网盘提取码自动获取:开源工具baidupankey终极指南
  • 用自然语言生成数据可视化:PlotAI如何用LLM降低数据分析门槛
  • 2026年口碑好的呼市消防资质代办/呼市电力资质代办/呼市环保资质代办/呼市钢结构资质代办行业公司推荐 - 行业平台推荐
  • Qubes OS自动化管理工具qubes-claw:声明式配置与安全隔离实践
  • 保姆级排查指南:从Win+R输入ncpa.cpl开始,一步步解决eNSP Cloud网卡显示不全
  • 别再手动写JPA实体了!用JPA Buddy插件5分钟搞定Spring Boot数据层开发(附Lombok避坑技巧)
  • Hygraph官方示例库:一站式掌握Headless CMS与现代前端框架集成
  • 基于Raspberry Pi Pico的旋转编码器USB HID鼠标开发指南
  • 2026冷热一体机厂家推荐:高温热泵机/螺杆式冷水机生产厂家+气悬浮冷水机生产厂家+低温冷冻机厂家推荐 - 栗子测评
  • 2026年4月广东做钢件的车床定制推荐,直Y/排刀机/四轴机/正交Y/双主轴/双主轴双排刀/动力刀塔,车床定制怎么选择 - 品牌推荐师