1.SQL执行计划结果与分析篇
在数据库中,想看到SQL的执行效率怎么样需要用到关键字EXPLAIN,通过EXPLAIN可以看到SQL的执行效率分析结果,这个分析结果现在还是个浓缩的信息,如果还想要获取进一步的信息,还需要自己去分析结果的内容。SQL查询的优化通常依赖于索引。而这个结果也同时可以看到索引的调用状况。
EXPLAIN的使用:
非常简单,将关键字放在你所需要分析的SQL语句之上,一起执行,就可以得到结果。
例如:
EXPLAIN
SELECT * FROM Sdent WHERE name = ‘张三’
使用EXPLAIN关键字获取到SQL执行效率结果后,显示的是一个多字段的结果集,这个结果集就是我们需要分析的结果了。
我们需要看的字段不多,只有以下字段需要重点关注:table、type、possible_keys、key、ref、rows、filtered这几个字段,至于Extra只是给了个空泛的分析结果,至于为什么会导致结果的产生,还是要去分析的。
Table字段 : 这个字段表示表名,但他的顺序通常表示表的执行顺序。
Type字段 : 这个字段通常表示字段的访问类型,他是SQL查询优化分析结果的一个重要指标,性能从高到低:system -> const -> eq_ref -> ref -> range -> index -> all。在此之外还有 index_manger,这个表示走的索引合并。
Pssible_keys字段 : 这个字段通常表示涉及到的几个索引,当表中有多个索引时,且SQL涉及