01_MySql日常使用整理_explain使用

本文详细解析MySQL的EXPLAIN命令,探讨id、select_type、table、partitions和type等关键字段的含义,帮助开发者理解SQL执行计划,优化数据库性能。同时,文章提到了MySQL分区、字段类型以及索引使用的相关知识链接。
摘要由CSDN通过智能技术生成

前言

当我们在开发的过程中会经常使用到explain查看sql的执行计划,今天来整理一个explain中各个字段分别代表着什么

1. 查看执行计划

在这里插入图片描述
简单介绍

字段对应含义
idselect 查询的顺序
select_type查询的类型
table查询时用到的表名称
partitions匹配的分区
type联接类型
possible_keys可能用到的索引
key查询实际用到的索引
key_len索引的长度
ref哪个字段或常数与 key 一起被使用
rows执行计划估算的扫描行数,不是精确值(innodb不是精确值,myisam是精确值,主要是因为innodb使用了mvcc)
filtered5.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 UNIONUNION中的第二个或后面的查询,依赖了外面的查询
UNION RESULTUNION的结果
SUBQUERY子查询中的第一个 SELECT
DEPENDENT SUBQUERY子查询中的第一个 SELECT,依赖了外面的查询
DERIVED用来表示包含在FROM子句的子查询中的SELECT,MySQL会递归执行并将结果放到一个临时表中。MySQL内部将其称为是Derived table(派生表),因为该临时表是从子查询派生出来的
DEPENDENT DERIVED派生表,依赖了其他的表
MATERIALIZED物化子查询
UNCACHEABLE SUBQUERY子查询,结果无法缓存,必须针对外部查询的每一行重新评估
UNCACHEABLE UNIONUNION属于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需要进行嵌套循环计算。

待整理:

参考文档:
https://blog.csdn.net/lilongsy/article/details/95184594
MySQL优化常见Extra分析——慢查询优化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值