MySQL使用explain语句性能分析详解

1.explain是如何进行工作的?

使用explain关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或者是表结构的性能瓶颈;
语法为:

explain SQL语句;

2.explain查询的内容

使用explain SQL语句;之后会出现如下的表头:
在这里插入图片描述
以下为对该表头的详细解释:

2.1 —— id

id表示select查询的序列号,包含一组数字,表示查询中执行select子句或操作表的顺序;
共分为三种情况:


Ⅰ id相同,执行顺序由上到下;
在这里插入图片描述


Ⅱ 如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行;
在这里插入图片描述


Ⅲ id有相同,也有不同,id越大优先级越高,id相同顺序执行;
在这里插入图片描述
此处的derived2表示id为1的执行表为id为2的表衍生出的虚表;

2.2 —— select_type

select_type表示查询的类型,主要用于区分普通查询、联合查询、子查询等复杂查询,有六种值:

Numselect_typeillustrate
1SIMPLE简单的select查询,查询中不包含子查询或UNION
2PRIMARY查询中若包含任何复杂的子部分,最外层查询标记为PRIMARY
3DEPENDENT SUBQUERY在select或where列表中包含了子查询
4DERIVED在FROM列表中包含的子查询被标记为DERIVED+id,MySQL会递归执行这些子查询,把结果放在衍生表中
5UNION若第二个select出现在union之后,则被标记为union;若union包含在from子句的子查询中,外层的select将会被标记为DERIVED
6UNION RESULT从union表获取结果的select

2.3 —— table

查询出的数据是关于哪一张表;

2.4 —— type

type表示访问类型排列,显示查询使用了何种类型,从最好到最差依次是:system > const > eq_ref > ref > fulltext >ref_or_null > index_merge > unique_subquery >index_subquery > range > index > ALL,对于常见的查询类型,有以下几种:

类型介绍
1system系统表只有一行记录,这是const类型的特例,可以忽略不计;
2const表示通过索引一次就找到,const用于比较primary key或unique索引。因为只匹配一行数据,所以速度快;
3eq_ref唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。常见于主键或唯一索引扫描
4ref非唯一性索引扫描,返回匹配某个单独值的所有行;
5range只检索给定范围的行,使用一个索引来选择行。一般就是在where语句中出现between、<、>、in等的查询,这种范围扫描索引比全表扫描要好,因为它只需要开始于索引的某一点,而结束语另一点,不用扫描全部索引
6index全索引扫描类型,index和ALL区别为index类型只遍历索引树。这通常比ALL快,因为索引文件通常比数据文件小;
7ALL全表扫描

2.5 —— possible key

possible key显示可能应用在表上的索引,一个或多个;查询涉及到的字段上若存在索引,则索引将被列出,但不一定在实际查询被使用;

2.6 —— key

实际使用的索引,如果为null,则表示没有使用索引;
查询中若使用了覆盖索引,则该索引只出现在key列表中;

2.7 —— key_len

表示索引中使用的字节数,可通过该列计算查询中使用的索引的长度。再不损失精度的情况下,长度越短越好;key_len显示的值为索引字段的最大可能长度,并非实际使用长度;
在这里插入图片描述
在同样的查询结果前提下,key_len所代表的精度越小越好;

2.8 —— ref

ref表示索引哪一列被使用了,如果可能的话,是一个常数。哪些列或者常量被用于查找索引列上的值
在这里插入图片描述
id相同,优先加载 t2 表;
t1 行 ref 为,表示复合索引 idx_col1_col2被充分使用
Ⅰ shared.t2.col1 表示该SQL在查询时用到了 shared库t2表col1列的索引,对应语句中t1.col1=t2.col1
Ⅱ const 表示查询出常量结果值,对用语句中 t1.col2 = ‘ac’;

2.9 —— rows

根据表统计信息及索引选用情况,大致估算出找到所需记录所需要读取的行数;

2.10 —— Extra

Extra列包含了不适合在其他列中显示但是又十分重要的额外信息;

类型解释
1Using filesort说明Mysql会对数据使用一个外部的索引排序,而不是按照表内的索引顺序进行读取。Mysql中无法利用索引完成的排序称作 “ 文件排序 ”,效率差;
2Using temporary使用了临时表保存中间结果,Mysql在对查询结果排序时使用临时表。常见于排序order by和分组查询group by,效率差;
3Using Index表示相应的select操作中使用了覆盖索引(Covering Index)避免了访问表的数据行,效率不错;如果同时出现Using where,表明索引被用来执行索引键值的查找;如果没有同时出现Using where,表明索引用来读取数据而非执行查找工作;
4Using where表明使用了where查询
5Using join buffer使用了连接缓存
6impossible wherewhere子句的值总是false,不能来获取任何元组
7select table optimized away在没有group by的情况下,基于索引优化MIN/MAX操作或者MyIsam存储引擎优化count(*)操作,不必等到执行阶段在进行计算,查询执行计划生成的阶段即完成优化;
8distinct执行distinct操作,再找到第一匹配的元素之后即停止寻找相同值的动作;

2.explain可以实现的功能

1.表的读取顺序(ID的顺序)
2.数据读取操作的操作类型
3.哪些索引可以使用
4.哪些索引被实际使用
5.表之间的引用
6.每张表有多少行被优化器查询

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值