MySQL 中如何查看 SQL 的执行计划?

SQL 语句前面使用 EXPLAIN 关键字:

EXPLAIN SELECT * FROM users WHERE id = 1;

|-----------------|------------------------------------------------------------------------------------|
| 字段 | 含义 |
| id | 查询的序号(如果是子查询或联合查询,会有多个 id)。 |
| select_type | 查询的类型(简单查询、子查询、联合查询等)。 |
| table | 查询涉及的表名。 |
| partitions | 查询时使用的分区(如果表有分区)。 |
| type | 查询的访问类型(性能从高到低:system> const> eq_ref> ref> range> index> ALL)。 |
| possible_keys | 可能使用的索引。 |
| key | 实际使用的索引。 |
| key_len | 使用的索引长度。 |
| ref | 使用的索引与哪些列或常量进行比较。 |
| rows | 估算的扫描行数。 |
| filtered | 计算结果集占扫描行数的百分比(MySQL 5.7+)。 |
| Extra | 额外信息(如 Using whereUsing indexUsing temporary 等)。 |


EXPLAIN 的关键字段详解

**type:**表示 MySQL 如何访问数据,性能从高到低排序。

  • system:表中只有一行数据(系统表)。
  • const:通过主键或唯一索引查询,结果只有一行。
  • eq_ref:在连接查询中,主键或唯一索引被使用,返回最多一行。
  • ref:使用非唯一索引查询,返回匹配的多行。
  • range:使用索引进行范围查询(如 BETWEENIN)。
  • index:全索引扫描(比全表扫描快,但仍需遍历索引)。
  • ALL:全表扫描(性能最差)。

**Extra:**提供查询的额外信息

  • Using where:查询使用了 WHERE 条件。
  • Using index:使用了覆盖索引(无需回表)。
  • Using temporary:使用了临时表(常见于排序或分组)。
  • Using filesort:使用了文件排序(性能较低)。
  • Using join buffer:使用了连接缓存(多表连接时)。

如何分析 EXPLAIN 结果

通过 EXPLAIN 结果,可以优化查询:

1.检查 type

  • 目标是使用 consteq_refrefrange
  • 避免 ALL(全表扫描)。

2.检查 key

    • 确保查询使用了索引。
    • 如果没有使用索引,考虑添加合适的索引。

3.检查 rows

  • 估算的扫描行数越少越好。
  • 如果行数过多,优化查询条件或索引。

4.检查 Extra

  • 避免 Using temporaryUsing filesort
  • 尽量使用 Using index

水平有限,如有错误,欢迎指正!

相关推荐
ForTodayzzZ7 分钟前
centos和ubuntu安装mysql教程
linux·mysql·ubuntu·centos
扣丁梦想家22 分钟前
《Spring Boot + MySQL高性能应用实战:性能优化技巧与最佳实践》
spring boot·后端·mysql
菠萝炒饭pineapple-boss29 分钟前
etcd 3.15 三节点集群管理指南
数据库·etcd
放学-别走36 分钟前
基于springboot 以及vue前后端分离架构的求职招聘系统设计与实现
java·mysql·spring·vue·毕业设计·springboot·毕设
暴躁茹1 小时前
正则表达式用法及其示例:匹配、查找、替换文本中的模式,及QT下如何使用正则表达式。
qt·mysql·正则表达式
智慧源点1 小时前
mysql大数量表添加索引方案
数据库·mysql
guihong0042 小时前
深入理解 Redis 设计与集群管理
数据库·redis·缓存
ADFVBM2 小时前
MySQL自启动失败(MySQL不能开机自启)解决方案_MySQL开机自启疑难杂症解决,适用Win11Win10
数据库·mysql
m0_748238272 小时前
MySQL 实验1:Windows 环境下 MySQL5.5 安装与配置
windows·mysql·adb
一只专注api接口开发的技术猿2 小时前
电商API接口设计:商品、订单与支付模块的微服务拆分实践
大数据·前端·数据库·微服务·云原生·架构