news 2026/4/15 19:25:38

我的笔记:怎么用 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/8 6:39:45

AppSmith革命性实时协作:多用户同时编辑的高效解决方案

AppSmith革命性实时协作:多用户同时编辑的高效解决方案 【免费下载链接】appsmith appsmithorg/appsmith: Appsmith 是一个开源的无代码开发平台,允许用户通过拖拽式界面构建企业级Web应用程序,无需编写任何后端代码,简化了软件开…

作者头像 李华
网站建设 2026/4/10 20:31:30

AG-UI智能应用开发框架:从理论到实践的完整指南

AG-UI智能应用开发框架:从理论到实践的完整指南 【免费下载链接】ag-ui 项目地址: https://gitcode.com/gh_mirrors/agu/ag-ui 当传统架构遇见AI代理:开发者的真实困境 在当前的AI应用开发浪潮中,开发者们面临着一个尴尬的现实&…

作者头像 李华
网站建设 2026/4/10 8:18:03

收藏必备:Agent工程——大模型应用开发的新范式

Agent工程是构建可靠LLM系统的新兴学科,通过构建-测试-发布-观察-优化-循环迭代,结合产品思维、工程和数据科学技能,解决大模型应用的不可预测性问题,让开发者能够在大模型环境中快速迭代,打造可信赖的智能系统。如果你…

作者头像 李华
网站建设 2026/4/12 19:17:10

告别频道混乱:一站式直播源管理解决方案

告别频道混乱:一站式直播源管理解决方案 【免费下载链接】allinone_format 本项目是对 https://hub.docker.com/r/youshandefeiyang/allinone /tv.m3u、/tptv.m3u、/migu.m3u 进行聚合 & 重新分组。 项目地址: https://gitcode.com/gh_mirrors/al/allinone_fo…

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

语音合成国际化:支持多语言扩展的可能性

语音合成国际化:支持多语言扩展的可能性 🌍 技术背景与演进趋势 随着全球化数字内容的快速增长,语音合成(Text-to-Speech, TTS)技术正从单一语言向多语言、跨文化、情感化方向演进。当前主流TTS系统大多聚焦于中文或…

作者头像 李华