news 2026/4/23 11:23:18

我的笔记:怎么用 MySQL 的 EXPLAIN 来分析 SQL

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
我的笔记:怎么用 MySQL 的 EXPLAIN 来分析 SQL


我一直觉得 SQL 慢,大多数时候不是数据库不行,而是我们对执行计划(execution plan)不熟,EXPLAIN是一个很实用的工具。它就像给 SQL 做一次“体检”,能帮我们看到优化空间。


我是怎么理解EXPLAIN

在我看来,EXPLAIN就是让数据库把它接下来要怎么执行这条 SQL 告诉你:

举个比喻:你写了个路线规划,EXPLAIN就是让数据库告诉你它“打算”怎么走这条路线。


基础使用方法

最常见的就是在你的 SELECT 语句前加上EXPLAIN

EXPLAINSELECT*FROMusersWHEREage>25;

运行之后会返回一张表格,常见字段有:

字段我理解的含义
id这是执行步骤的编号
select_type这个查询是简单查询还是联合查询
table当前这一行操作的是哪个表
type最关键 —— 访问类型,越好越靠前
key实际使用的索引
rows估算扫描的行数
Extra附加信息,比如是否使用文件排序、临时表等

我觉得最值得关注的几项

访问类型 (type)

我自己用的时候,最先盯着这一列看。

从好到差,大致顺序是:

const eq_ref ref range index ALL

可以这么理解:


实际使用的索引 (key)

这一列其实挺直观的:它会告诉你,数据库是不是用了你预期的索引。

举例来说:

EXPLAINSELECT*FROMusersWHEREid=123;

假设你有主键索引 id,那么key应该是这条主键索引。

如果key显示为NULL,那就说明没有用索引 —— 很可能会导致全表扫描。


扫描行数 (rows)

EXPLAIN会给出一个估算值,表示数据库预计要扫描多少行。

这个其实很关键,因为它能让你直观感受到:

“这个查询要扫描多少数据?”

比如扫描了 100 万行和扫描了 10 行,其性能差距显然是不一样的。


附加信息 (Extra)

这一列包含一些补充信息,我觉得看这一项能帮我发现:

比如如果出现了:

Using temporary; Using filesort

这通常说明这个查询在排序或分组时效率不高,这时候我就会考虑:

有没有必要增加合适的索引?


一个简单的例子

假设有这样一张表:

CREATETABLEorders(idBIGINTPRIMARYKEY,user_idBIGINT,amountDECIMAL(10,2),created_atDATETIME,INDEXidx_user(user_id));

我写了两条查询:

EXPLAINSELECT*FROMordersWHEREuser_id=100;

如果输出里面:

我觉得这是“合理使用索引”的情况。

再看看:

EXPLAINSELECT*FROMordersORDERBYamount;

可能出现:

说明这条排序没走索引,这时候我就会考虑:

“如果这条查询是常用的,是否应该在 amount 上加一个索引?”


我理解的几个优化思路

基于EXPLAIN的输出,我通常会这么判断:

查看是否走索引

key看成“有没有走索引”,没有的话就看是否需要加。

扫描行数是否合理

如果 rows 数特别大,那就说明过滤条件不够好或者没有索引。

注意Extra里是否有不良信息

比如:

这两个我都不太喜欢看到,它们往往意味着性能有提升空间。


我总结几点个人经验


结语

总的来说,我认为EXPLAIN就像是数据库对你说:

我打算怎么执行这条 SQL。

理解它,不是为了背输出字段,而是为了能根据结果判断这条 SQL 有没有优化的空间。

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

测试报告自动化生成与可视化实战

一、传统测试报告的痛点与自动化价值 手工编写测试报告存在三大致命缺陷: 时效滞后 - 平均耗时2-3小时/次,错过关键决策窗口 信息割裂 - 用例执行、缺陷数据、环境配置分散存储 可视化缺失 - 纯文本报告难以直观暴露质量趋势 自动化报告系统可实现&…

作者头像 李华
网站建设 2026/4/22 8:15:02

AppSmith零代码开发:5分钟搭建你的第一个企业级应用

AppSmith零代码开发:5分钟搭建你的第一个企业级应用 【免费下载链接】appsmith appsmithorg/appsmith: Appsmith 是一个开源的无代码开发平台,允许用户通过拖拽式界面构建企业级Web应用程序,无需编写任何后端代码,简化了软件开发流…

作者头像 李华
网站建设 2026/4/16 7:48:11

小样本学习:如何用少量数据训练高性能CRNN模型

小样本学习:如何用少量数据训练高性能CRNN模型 📖 技术背景与问题提出 在OCR(光学字符识别)领域,高质量标注数据的获取成本极高,尤其是中文场景下,字体多样、背景复杂、光照不均等问题使得模型泛…

作者头像 李华
网站建设 2026/4/19 13:48:39

10个必知Docker命令实战案例解析

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个Docker命令实战案例展示平台,包含10个典型应用场景:1) 多容器编排 2) 日志查看与分析 3) 资源监控 4) 数据卷管理 5) 网络配置等。每个案例提供&am…

作者头像 李华
网站建设 2026/4/16 12:16:27

Wan2.1架构新突破:14B参数图像转换模型如何实现效率倍增?

Wan2.1架构新突破:14B参数图像转换模型如何实现效率倍增? 【免费下载链接】Wan2.1-I2V-14B-480P-StepDistill-CfgDistill-Lightx2v 项目地址: https://ai.gitcode.com/hf_mirrors/lightx2v/Wan2.1-I2V-14B-480P-StepDistill-CfgDistill-Lightx2v …

作者头像 李华