执行计划深度解析:从 type 到 Extra,榨干 EXPLAIN 的价值

本文涉及的产品
RDS Agent(兼容OpenClaw),2核4GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 详解 MySQL EXPLAIN:从 type、key_len 到 Extra 各字段含义与优化技巧,用快递分拣等生动类比讲透执行计划。涵盖联合索引使用原则、filesort 本质、filtered 作用及实战调优案例,助你快速定位慢查询根源。

大家好,我是小耶,写功课只是为了我踩过的坑,你们别再踩了!

你肯定用过 EXPLAIN 看 SQL 的执行计划,但你有没有真正看全过?type 到底有几种取值?Extra 里的 Using indexUsing whereUsing temporaryUsing filesort 分别什么意思?key_len 怎么算?filtered 有什么用?今天我们就来把 EXPLAIN 的输出彻底讲透。

  • type 相当于分拣效率:最快的是“直接按门牌号送”(const),最慢的是“翻遍整个仓库”(ALL)。
  • possible_keys = 可能用的传送带,key = 实际选的传送带。
  • rows = 需要检查的包裹数量。
  • filtered = 初步分拣后还需要人工二次分拣的比例。
  • Extra = 额外操作标记,如“用了传送带但还要人工挑拣”(Using where)、“需要临时堆货”(Using temporary)。

一、EXPLAIN 输出列完整解读

我们用 EXPLAIN SELECT ... 会得到一张表,每个列的含义如下:

列名 含义 关键点
id SELECT 的标识序号 越大越先执行;相同则从上到下
select_type 查询类型 SIMPLE、PRIMARY、SUBQUERY、DERIVED、UNION 等
table 表名或别名 可能是临时表名()
partitions 匹配的分区 分区表时有用
type 连接类型(重要) 性能从好到差:system > const > eq_ref > ref > range > index > ALL
possible_keys 可能使用的索引 列出候选索引
key 实际使用的索引 如果 NULL 表示没用到索引
key_len 使用索引的长度(字节) 判断联合索引用了多少列
ref 索引列与哪个值比较 常量 const 或 列名
rows 预估需要扫描的行数 越大越差
filtered 存储引擎返回的行中满足剩余条件的比例 100% 最好
Extra 额外信息 Using index、Using where、Using temporary、Using filesort 等

二、type 详解:性能的关键指标

type 表示 MySQL 如何查找表中的行,按性能从最优到最差排序:

type 含义 示例 出现条件
system 系统表,只有一行 极少见 系统表或 const 的特例
const 最多匹配一行,用主键或唯一索引等值查询 WHERE id = 1 主键或唯一索引,且查询结果为常量
eq_ref 使用唯一索引进行关联,每个关联只返回一行 JOIN ... ON t1.id = t2.id 且 t2.id 是主键 被驱动表使用主键或唯一索引连接
ref 使用非唯一索引或前缀索引进行等值匹配 WHERE name = 'abc'(name 有普通索引) 索引列不是唯一或可为 NULL
range 索引范围扫描 WHERE id BETWEEN 1 AND 100IN>< 索引列上的范围条件
index 全索引扫描 索引覆盖但没过滤条件 遍历整个索引树
ALL 全表扫描(最差) 无索引或优化器认为全表更快 大表且无有效索引

优化目标:至少达到 range 级别,争取达到 refconst

案例

-- type = ALL 很差
EXPLAIN SELECT * FROM orders WHERE amount > 100;
-- 添加索引后 type 变为 range
ALTER TABLE orders ADD INDEX idx_amount(amount);

三、Extra 详解:优化器还做了什么?

Extra 列包含关于查询执行的额外信息,很多关键优化线索都在这里:

Extra 信息 含义 优劣 优化方向
Using index 使用了覆盖索引,不回表 ✅ 好 继续保持
Using where 存储引擎返回后在 Server 层过滤 🟡 普通 尝试将过滤条件移到索引中
Using temporary 使用了临时表(通常用于 GROUP BY 或 DISTINCT) ⚠️ 差 优化 GROUP BY/ORDER BY 或加索引
Using filesort 需要额外排序,不能利用索引排序 ⚠️ 差 对 ORDER BY 列加索引
Using index condition 使用索引下推(ICP) ✅ 好 MySQL 5.6+ 自动优化
Using join buffer 连接使用了 Buffer(Block Nested Loop) 🟡 普通 加索引避免 Buffer
Impossible WHERE WHERE 条件永远为假 无需优化 检查 SQL 逻辑
No tables used 没有 FROM 或 FROM DUAL - -

注意Using filesort 不是真的用文件,而是指无法利用索引排序,需要在内存或磁盘中排序。当排序结果集大时很慢。

案例

-- Using filesort
EXPLAIN SELECT * FROM orders ORDER BY create_time;
-- 加索引后 Using filesort 消失
ALTER TABLE orders ADD INDEX idx_create_time(create_time);

四、组合索引与 key_len 实战

key_len 表示 MySQL 在索引中实际使用的字节数。通过它可判断联合索引使用了多少列。

计算规则

  • 列长度:INT=4, BIGINT=8, DATE=3, TIMESTAMP=4, CHAR(n)=n×字符集字节数(utf8mb4=4),VARCHAR(n)=n×4+2。
  • 允许 NULL 额外 +1。

示例:索引 (user_id, log_date, type),user_id INT NOT NULL (4),log_date DATE NOT NULL (3),type TINYINT (1)。查询 WHERE user_id=1 AND log_date='2026-06-01'key_len=4+3=7,说明用到了前两列。

联合索引使用原则:最左前缀,且中间的列不能跳过。如果跳过了某列,后面的列不会被使用。


五、filtered 的作用

filtered 表示存储引擎返回的行中,满足剩余 WHERE 条件的比例(估算)。100% 表示所有返回行都满足条件。如果 filtered 很小(如 10%),说明索引过滤后还要过滤掉 90% 的行,回表成本高。

用法:在 JOIN 中,驱动表的 filtered 值直接影响被驱动表的读取次数。


六、实战案例优化全过程

原始 SQL

SELECT * FROM orders 
WHERE customer_id = 12345 
  AND status = 'PAID' 
  AND create_time > '2026-01-01'
ORDER BY create_time DESC
LIMIT 10;

原执行计划:type=ref,key=customer_id,rows=1000,Extra="Using where; Using filesort"。

问题分析

  • 用了 customer_id 索引,但 status 和 create_time 过滤在回表后执行。
  • filesort 因为 create_time 没在索引中用于排序。

优化方案:建立联合索引 (customer_id, status, create_time)

新执行计划:type=ref,key=联合索引,key_len=4+?+3,Extra=无 filesort(因为索引已排序)。

效果:查询从 0.5 秒降到 0.02 秒。


七、总结与实用检查清单

阅读 EXPLAIN 时按以下顺序检查:

  1. type:是否出现了 ALL 或 index?如果是,考虑加索引。
  2. key:是否为 NULL?是则索引没用上。
  3. rows:是否远大于预期?检查索引选择性。
  4. Extra:是否出现 Using temporary 或 Using filesort?优化排序和分组。
  5. filtered:是否低于 30%?检查索引是否能覆盖更多过滤条件。

小耶在手,SQL 不愁

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

相关文章
|
18天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
6738 30
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
3天前
|
数据采集 人工智能 前端开发
让 Coding Agent 从黑盒到透明:阿里云 Agent 观测审计数据采集实践
AI Agent 规模化落地带来执行黑盒、行为难追溯、成本难度量三大难题。阿里云基于 OTel 标准,面向 Coding Agent、个人通用助理和框架型 Agent,推出 LoongSuite Pilot、插件及探针等无侵入采集方案,让 Agent 实现可看见、可分析、可审计、可治理。
603 138
|
3天前
|
人工智能 弹性计算 运维
阿里云发布堡垒机智能运维Agent,运维交互进入自然语言新时代
支持自然语言运维,提升效率与安全双保障。
1143 0
|
10天前
|
人工智能 安全 定位技术
CodeGraph深度解析 让Claude Code工具调用直降七成的核心原理与实操教程
如今以Claude Code为代表的AI编程智能体已经成为开发者日常编码、项目重构、漏洞修复的必备工具。但在长期使用过程中,几乎所有开发者都会遇到同一个明显痛点:AI虽然具备强大的代码生成与分析能力,却常常陷入盲目探索的循环中。
1158 1
|
13天前
|
存储 定位技术 数据库
CodeGraph 如何让 Claude Code减少 7 成工具调用?
CodeGraph 为 Coding Agent 提供本地代码知识图谱,把函数、类、调用链和框架路由提前整理成“项目地图”,减少盲目搜索和文件读取。它不是新 Agent,而是上下文基础设施,让 Agent 更快找到正确代码路径,平均减少 7 成工具调用。
1269 3
|
10天前
|
人工智能 弹性计算 安全
阿里云618活动时间、活动入口、优惠活动详细解读
2026年阿里云618创新加速季已全面开启,作为年度力度最大的云产品促销活动,本次大促覆盖轻量应用服务器、ECS云服务器、GPU云服务器、数据库、AI算力、安全服务、CDN等全品类产品,推出5亿元算力补贴、新用户限时秒杀、普惠满减、企业专享、免费试用、云大使返佣等多重福利,个人开发者、中小企业、AI团队均可享受专属低价。本文将系统梳理2026年阿里云618活动的完整时间节点、官方参与入口、各类优惠细则、使用规则、热门产品推荐及实操代码,帮助用户精准参与、高效省钱,以最低成本完成上云部署。
948 5
|
9天前
|
人工智能 自然语言处理 安全
Vibe Coding 实战:别盲目跟风,先分清 vibe coding 适合什么场景
本文系统总结vibe coding实战经验:明确其适用场景(原型、小工具、标准化模块),剖析5步落地流程(场景判定→结构化提示词→目录初始化→分模块生成→自动化校验),指出四大常见误区,并推荐适配工具Trae。强调“场景匹配+规则前置”是提效关键,避免盲目套用。
787 1