Explain工具简介
1.id列
id列的编号是select的序列号,有几个select就有几个ID,并且id的顺序是按select的顺序增长的。
id列越大执行优先级越高,id相同则从上往下执行,id为null最后执行。
2.select_type列
select_type表示对应的是简单还是复杂的查询。
(1)simple:简单查询,查询不包含子查询和union
(2)primary:复杂查询中最外层的select
(3)derived:包含在from子句中的子查询,mysql会将结果存放在一个临时表中。
(4)subquery:包含在select中的子查询(不在from子句中)
(5)union:
3.table 列
这一列表示explain的一行正在访问那张表。
4.type列
这一列表示关联类型或访问类型,即mysql决定如何查询表中的行,查找数据行记录的大概范围。
依此从优到差分别为:system>const>eq_ref>ref>range>index>ALL
5.possible_keys列
这一列显示查询可能使用哪些索引来查找。
explain时可能出现possible_keys有列,而key显示NULL的情况,这种情况是因为表中数据不多,mysql认为索引对此查询帮助不大,选择了全表查询。如果该列是NULL,则没有相关的索引。在这种情况下,可以通过检查where子句看是否可以创造一个适当的索引来提高查询性能,然后用explain查看效果。
6.key列
这一列显示mysql实际采用那个索引来优化对该表的访问。
如果没有使用索引,则该列为null。
7.key_len列
这一列显示了mysql在索引里使用的字节数,通过这个值可以算出具体使用了索引中的那些列。
例:film_actor的联合索引idex_film_actor_id由film_id和actor_id两个int列组成,并且每个int是4个字节。通过结果中的key_len=4可推断出查询使用了第一个列:film_id列来执行索引查找。
key_len计算规则:
char(n):n字节长度,
varchar(n):2字节存储字符串长度,如果是utf-8, 则长度3n+2
int:4字节
bigint:8字节
date:3字节
datetime:8字节
如果字段允许为null,需要1字节记录是否为null
8.ref列
显示使用哪个列或常数与key一起从表中选择行。
9.rows列
这一列是mysql估计要读取的行数。
10.Extra列
(1)Using index: 使用覆盖索引
(2)Using where:使用where语句来处理结果,查询的列未被索引覆盖
(3)Using index condition:查询的列不完全别索引覆盖,where条件是一个范围值。
(4)Using temporary: mysql需要创建一张临时表来处理查询,出现这种情况一般要进行有话,首先通过索引进行优化。
1.name没有创建索引,创建张临时表来DISTICNT。
2.name创建了idx_name索引, 次查询Extra是Using index,没有使用临时表
(5)Using filesort: 将用外部排序而不是索引排序,数据较小时在内存中排序,否则需要在磁盘上进行排序。需要索引进行优化。
1.name未创建索引,会扫描整张表,保存排序的关键字name和对应的id,然后排序name检索行记录。
2.name创建了idx_name索引,查询时Extra为Using index。
6.Select tables optimized away : 使用了聚合函数来访问索引的某个字段