sql性能分析之explain
1 explain的基础概念
1.1 explain是什么,
简而言之就是查看查看执行计划,使用explain关键字可以模拟优化器执行SQL查询语句,从而知道mysql是如何处理你的SQL语句的,分析你的查询语句或是表结构的性能瓶颈.
1.2 explain能干什么
1.表的读取顺序
2.数据读取操作的操作类型
3.哪些索引可以使用
4.哪些索引被实际使用
5.表之间的引用
6.每张表有多少行被优化器查询
1.3 怎么玩?
explain+sql语句
执行计划包含的信息
2 explain之详细介绍
我们可以通过explain+SQL的方式来分析SQL.从上图中我们可以得到一个表,该表的字段下面将详细介绍
2.1 id
select 查询的***,包含一组数字,表示查询中执行select子句或者操作表的顺序,有三种情况
2.1.1 id相同,执行顺序由上至下
从图中可以看出mysql并没有按照我们预期的加载表的顺序(t1,t2,t3)而是先加载t1,t3,t2.第一列的id值相同,执行顺序由上往下.(当然也有可能按照t1,t2,t3的顺序,具体的顺序要根据mysql的优化器自己选择,这里只是用来佐证id相同顺序由上往下).例如下图:
2.1.2 id不同
如果是子查询,id的序号会递增,id的值越大优先级越高,越先被执行.
2.1.3 id相同不同,同时存在.
id如果相同,可以认为是一组,从上往下顺序执行,在所有组中,id值越大,优先级越高,越先执行.
衍生=DERIVE
3.1 select_type
3.1.1 有哪些
1.simple -----简单的select查询,查询中不包含子查询或者union
2.primary-----查询中不包含任何复杂的子部分,最外层查询被标记为primary
3.subquery-----在select或者where列表包含了子查询
4.derived------在from列表中包含的子查询被标记为derived(衍生),mysql会递归执行这些子查询,把结果放在临时表里
5.union---------若第二个select出现在union之后,则被标记为union
6.union result----从union表获取结果的select
4.1 table
太简单了,就不说了..........
5.1 type
type有以下几种类型
从最好到最差依次是:system->const->eq_ref->ref->range->index->ALL
system---->表中只有一行记录,是const类型的特例,平时不会出现,也可以忽略不计
const------>表示通过索引一次就找到了,const用于比较primarykey或者unique索引.因为只匹配一行数据,所以很快.例如将主键置
------>于where中,MySQL就能将该查询转换为一个常量.
eq-ref------>唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配.常见于主键或唯一索引扫描.
ref------>非唯一性索引扫描,返回匹配某个单独值的所有行.本质上也是一种索引访问,它返回某个单独
------->值的行,然而,它可能会找到多个符合条件的,所以它应该属于查找和扫描的混合体.
range------>只检索给定范围的行,使用一个索引来选择行.key列显示使用了哪个索引,一般就是你的where语句中
------->出现了between,<,>,in等的查询.这种范围扫面索引比全表扫描要好,因为它只需要开始于索引的某一点,
------->而结束于另一点,不需要扫描全部索引.
index------>(FullIndex Scan)index和ALL的区别是index类型只遍历索引树,这通常比ALL快,因为索引文件通常比数据文件小.
------>(也就是说虽然ALL和index都是读全表,但是index是从索引中读取的,而ALL是从硬盘中读取的)
all------>(FullTable Scan)全表扫描,将遍历全表以找到匹配的行