您的位置:首页 > 数据库 > MySQL

MySQL 的Explain分析

2019-06-14 11:03 148 查看
[code]CREATE TABLE `a` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`uid` int(10) unsigned DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `idx_uid` (`uid`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

Explain
 输出的字段内容

id, select_type, table, partitions, type, possible_keys, key, key_len, ref, rows,filtered,extra

列名 含义
id 查询语句的标识
select_type 查询的类型
table 当前行所查的表
partitions 匹配的分区
type 访问类型
possible_keys 查询可能用到的索引
key mysql 决定采用的索引来优化查询
key_len 索引 key 的长度
ref 显示了之前的表在key列记录的索引中查找值所用的列或常量
rows 查询扫描的行数,预估值,不一定准确
filtered 查询的表行占表的百分比
extra 额外的查询辅助信息

常用字段详细介绍

1.id: 是用来顺序标识整个查询中 select 语句的,在嵌套查询中id越大的语句越先执行

2.select_type:

•simple: 简单的SELECT(不使用UNION或子查询)

•primary: 最外面的SELECT

•union: UNION中的第二个或更高的SELECT语句

•dependent union: UNION中的第二个或更高的SELECT语句,取决于外部查询

•union result: UNION的结果

•subquery: 在子查询中首先选择SELECT

•dependent subquery: 子查询中的第一个SELECT,取决于外部查询•derived: 派生表——该临时表是从子查询派生出来的,位于from中的子查询

•uncacheable subquery: 无法缓存结果的子查询,必须为外部查询的每一行重新计算

•uncacheable union: 在UNION中的第二个或更晚的选择属于不可缓存的子查询

3.table: 每一行引用的表名

4.type: 从上到下效果依次降低

•system: const 的一种特例,表中只有一行数据

•const: 当确定最多只会有一行匹配的时候,MySQL优化器会在查询前读取它而且只读取一次,因此非常快。使用主键查询往往就是 const 级别的,非常高效

•eq_ref: 最多只返回一条符合条件的记录,通过使用在两个表有关联字段的时候

•ref: 通过普通索引查询匹配的很多行时的类型

•fulltext: 全文索引

•ref_or_null: 跟 ref 类似的效果,不过多一个列不能 null 的条件

•index_merge: 此连接类型表示使用了索引合并优化。在这种情况下,输出行中的 key 列包含使用的索引列表,key_len包含所用索引的最长 key 部分列表

•unique_subquery: 在使用 in 查询的情况下会取代 eq_ref

•range: 范围扫描,一个有限制的索引扫描。key 列显示使用了哪个索引。当使用=、 <>、>、>=、<、<=、IS NULL、<=>、BETWEEN 或者 IN 操作符,用常量比较关键字列时,可以使用 range

•index: 类似全表扫描,只是扫描表的时候按照索引次序进行而不是行。主要优点就是避免了排序, 但是开销仍然非常大。如在Extra列看到Using index,说明正在使用覆盖索引,只扫描索引的数据,它比按索引次序全表扫描的开销要小很多

•ALL: 全表扫描

5.possible_key: MySQL 可能采用的索引,但是并不一定使用

6.key: MySQL 正真使用的索引名称

7.rows: 预估的扫描行数,只能参考不准确

8.extra: 该列包含了很多额外的信息,包括是否文件排序,是否有临时表等,很多时候这个字段很有用能提供很多信息

 

转自:https://mp.weixin.qq.com/s/yOZ3WglZMZJaV9H7ruzA6g

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: