MySQL explain 例子_MySql]explain用法及实践

explain对我们优化sql语句是非常有帮助的。可以通过explain+sql语句的方式分析当前sql语句。

例子

EXPLAIN SELECT dt,method,url FROM app_log WHERE id=11789

aa404f6788c8499a9a28459b948ea09c.png

table

显示这一行数据属于哪张表,若在查询中为select起了别名,则显示别名。

EXPLAIN SELECT dt,method,url FROM app_log AS temp WHERE id=11789

2d3a784cf853acde2d262e13e90a585a.png

type

在表里查到结果所用的方式。包括(性能有差——>高): All | index | range | ref | eq_ref | const,system | null |

all:全表扫描,MySQL 从头到尾扫描整张表查找行。

EXPLAIN SELECT dt,method,url FROM app_log AS temp LIMIT 100

3305e85a659ca77d53a6f09157b91f54.png

注意:这里虽然使用limit但并不能改变全表扫描。

index:按索引扫描表,虽然还是全表扫描,但优点是索引是有序的。

EXPLAIN SELECT id FROM app_log AS temp LIMIT 100

dda3442270e1b4f6f3ddc5db7500de7d.png

range:以范围的方式扫描索引。比较运算符,以及in的type都是range。

EXPLAIN SELECT * FROM app_log AS temp WHERE id>100 LIMIT 199

487a9f733022c41b84e86424c9c63fe4.png

ref:非唯一性索引访问

EXPLAIN SELECT * FROM app_log AS temp WHERE dt='2015-01-02' LIMIT 199

4c4c83129941fab0ea0825a18d0b5f69.png

eq_ref:使用唯一性索引查找(主键或唯一索引)

EXPLAIN SELECT * FROM app_log JOIN app_details_log USING(id)

d720ede579797666e9ad62efe7bf689b.png

先全表扫描了app_details_log表,然后在对app_log进行eq_ref查找。因为app_log的id字段是主键。如果此时删除app_log的id为主键,则都会进行全表扫描。

const:常量,在整个查询过程中这个表最多只会有一条匹配的行,比如主键 id=1 就肯定只有一行,只需读取一次表数据便能取得所需的结果,且表数据在分解执行计划时读取。

EXPLAIN SELECT * FROM app_log WHERE id=11790

3f833897e2c7ba900a0b5a39c0fe9082.png

注意:system 是 const 类型的特例,当表只有一行时就会出现 system 。

null:在优化的过程已经得到结果,不再需要访问表或索引。例如表中并不存在id=1000的记录。

EXPLAIN SELECT * FROM app_log WHERE id=1000

f5a9b9d7ea42fcfccae30b6dbcede2ac.png

possible_keys

可能被用到的索引。

EXPLAIN SELECT * FROM app_log WHERE id>100 LIMIT 100 ;

b984b2194f679b4abacc4fda71675a0a.png

Key

查询过程中实际用到的索引,例子如上图,实际用的索引列为主键列。

key_len

索引字段最大可能使用的长度。例如上图中,Key_len:4,因为主键是int类型,长度为4.

ref

指出对key列所选择的索引的查找方式,常见的有const,func,null,具体字段名。当key列为null,即不使用索引时,此值也为null.

rows

mysql估计需要扫描的行数,只是一个估算。

Extra

这个显示其他的一些信息,但对优化sql也非常的重要。

using Index:此查询使用了覆盖索引(Convering Index),即通过索引就能返回结果,无需访问表。弱没显示“Using Index”表示读取了表数据。

EXPLAIN SELECT id FROM app_log;

f01d0d644e5bdefeeea4ab62f85507d0.png

因为 id 为主键索引,索引中直接包含了 id 的值,所以无需访问表,直接查找索引就能返回结果。

using where:mysql从存储引擎收到行后再进行“后过滤(Post-filter)”。后过滤:先读取整行数据,再检查慈航是否符合where的条件,符合就留下,不符合便丢弃。检测是在读取行后进行的,所以叫后过滤。

EXPLAIN SELECT id FROM app_log WHERE id>100 LIMIT 100;

68ee025add31ea3eead01a5277ccc284.png

using temporary:使用到临时表,在使用临时表的时候,Extra为这个值。

using filesort:若查询所需的排序与使用的索引的排序一直,因为索引已排序,因此按索引的顺序读取结果返回,否则,在取到结果后,还需要按查询所需的顺序对结果进行排序,这时就会出现using filesort。

EXPLAIN SELECT id FROM app_log WHERE id>100 GROUP BY dt;

e022cf3b30a830e0b3e04835881305bc.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值