explain需要记住的知识点
前言
当我们在开发的过程中会经常使用到explain查看sql的执行计划,今天来整理一个explain中各个字段分别代表着什么
1. 查看执行计划
简单介绍
字段 | 对应含义 |
---|---|
id | select 查询的顺序 |
select_type | 查询的类型 |
table | 查询时用到的表名称 |
partitions | 匹配的分区 |
type | 联接类型 |
possible_keys | 可能用到的索引 |
key | 查询实际用到的索引 |
key_len | 索引的长度 |
ref | 哪个字段或常数与 key 一起被使用 |
rows | 执行计划估算的扫描行数,不是精确值(innodb不是精确值,myisam是精确值,主要是因为innodb使用了mvcc) |
filtered | 5.7之后的版本默认就有这个字段,不需要使用explain extended了。这个字段表示存储引擎返回的数据在server层过滤后,剩下多少满足查询的记录数量的比例,注意是百分比,不是具体记录数。 |
Extra | 额外的信息 |
1.1 id 查询顺序
该语句的唯一标识。如果explain的结果包括多个id值,则数字越大越先执行;而对于相同id的行,则表示从上往下依次执行。
1.2 select_type查询类型
类型 | 作用 |
---|---|
SIMPLE | 简单查询(未使用UNION或子查询) |
PRIMARY | 最外层的查询 |
UNION | 在UNION中的第二个和随后的SELECT被标记为UNION。如果UNION被FROM子句中的子查询包含,那么它的第一个SELECT会被标记为DERIVED。 |
DEPENDENT UNION | UNION中的第二个或后面的查询,依赖了外面的查询 |
UNION RESULT | UNION的结果 |
SUBQUERY | 子查询中的第一个 SELECT |
DEPENDENT SUBQUERY | 子查询中的第一个 SELECT,依赖了外面的查询 |
DERIVED | 用来表示包含在FROM子句的子查询中的SELECT,MySQL会递归执行并将结果放到一个临时表中。MySQL内部将其称为是Derived table(派生表),因为该临时表是从子查询派生出来的 |
DEPENDENT DERIVED | 派生表,依赖了其他的表 |
MATERIALIZED | 物化子查询 |
UNCACHEABLE SUBQUERY | 子查询,结果无法缓存,必须针对外部查询的每一行重新评估 |
UNCACHEABLE UNION | UNION属于UNCACHEABLE SUBQUERY的第二个或后面的查询 |
1.3 table
表示当前这一行正在访问哪张表,如果SQL定义了别名,则展示表的别名
1.4 partitions
当前查询匹配记录的分区。对于未分区的表,返回null
1.5 type(重点)
类型 | 作用 |
---|---|
system | 表只有一行,MyISAM引擎。 |
const | 常量连接,表最多只有一行匹配,通用用于主键或者唯一索引比较时 |
ref | 单表查询使用索引时用到了=查询 |
eq_ref | 表关联查询使用索引=时 |
range | 范围查询 |
index | 索引上全部扫描 |
all | 全表扫描 |
1.5 Extra(重点)
类型 | 作用 |
---|---|
using where | 使用where条件进行过滤 |
using index | 使用过滤条件是索引字段 |
using index condition | 查询字段需要进行回表查询 |
using filesort | 在排序过程中没有索引 |
using temporary | 使用到了临时表 |
using join buffer | 需要进行嵌套循环计算。 |
待整理:
- MySql的分区:https://www.jb51.net/article/212430.htm
- 为什么HashMap中使用红黑树,而不是AVL:https://www.cnblogs.com/deepalley/p/13447970.html
- MySql的字段类型及对应的长度,
- Sql语句默认使用索引的规则,如何强制使用引用
参考文档:
https://blog.csdn.net/lilongsy/article/details/95184594
MySQL优化常见Extra分析——慢查询优化