mysql索引实践(一)

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 : 使用了聚合函数来访问索引的某个字段

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值