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)indexALL的区别是index类型只遍历索引树,这通常比ALL,因为索引文件通常比数据文件小.

          ------>(也就是说虽然ALLindex都是读全表,但是index是从索引中读取的,ALL是从硬盘中读取的)


   all------>(FullTable Scan)全表扫描,将遍历全表以找到匹配的行


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值