mysql _ explain用法

一. 举例 : explain select * from as_house ; (explain 只要放在select语句前就可以)

explain的例子

从图中可以看出explain的结果,总共有10个参数

(1)id :SELECT 查询的标识符. 每个 SELECT 都会自动分配一个唯一的标识符.

(2)select _type : 索引类型

select_type值的类型

(3)table : 索引所在的表

(4)type:  type 字段比较重要, 它提供了判断查询是否高效的重要依据依据. 通过 type 字段, 我们判断此次查询是 全表扫描 还是 索引扫描 等.

    type 常用的取值有:

    a>. system: 表中只有一条数据. 这个类型是特殊的 const 类型.

     b>. const: 针对主键或唯一索引的等值查询扫描, 最多只返回一行数据. const 查询速度非常快, 因为它仅仅读取一 次    即可.

     c> .eq_ref: 此类型通常出现在多表的 join 查询, 表示对于前表的每一个结果, 都只能匹配到后表的一行结果. 并  且查询的比较操作通常是 =,查询效率较高

      d> . ref: 此类型通常出现在多表的 join 查询, 针对于非唯一或非主键索引, 或者是使用了 最左前缀 规则索引的查询.

       e> . range: 表示使用索引范围查询, 通过索引字段范围获取表中部分数据记录. 这个类型通常出现在 =, <>, >, >=, <, <=, IS NULL, <=>, BETWEEN, IN() 操作中.

        当 type 是 range 时, 那么 EXPLAIN 输出的 ref 字段为 NULL, 并且 key_len 字段是此次查询中使用到的索引的最长的那个.

       f>.index: 表示全索引扫描(full index scan), 和 ALL 类型类似, 只不过 ALL 类型是全表扫描, 而 index 类型则仅仅扫描所有的索引, 而不扫描数据.

index 类型通常出现在: 所要查询的数据直接在索引树中就可以获取到, 而不需要扫描数据. 当是这种情况时, Extra 字段 会显示 Using index.

       g>.ALL: 表示全表扫描, 这个类型的查询是性能最差的查询之一. 通常来说, 我们的查询不应该出现 ALL 类型的查询,

因为这样的查询在数据量大的情况下, 对数据库的性能是巨大的灾难. 如一个查询是 ALL 类型查询, 那么一般来说可以对相应的字段添加索引来避免.

通常来说, 不同的 type 类型的性能关系如下:

 ALL < index < range ~ index_merge < ref < eq_ref < const < system

(5)possible_keys : 可能应用在这张表中的索引. 如果为空,没有可能的索引

(6)key : 实际使用的索引。如果为null,则没有使用索引。很少的情况下,mysql会选择优化不足的索引。这种情况下,可以在select语句中使用use  index(indexname)来强制使用一个索引或者用 ignore index(indexname)来强制mysql忽略索引

(7)key_len:使用的索引的长度。在不损失精确性的情况下,长度越短越好

    表示查询优化器使用了索引的字节数. 这个字段可以评估组合索引是否完全被使用, 或只有最左部分字段被使用到.

(8)ref :显示索引的哪一列被使用了,如果可能的话,是一个常数

   此类型通常出现在多表的 join 查询, 针对于非唯一或非主键索引, 或者是使用了 最左前缀 规则索引的查询(结合4中type = ref 理解)

(9)rows: 结果行数.  也是一个重要的字段. MySQL 查询优化器根据统计信息, 估算 SQL 要查找到结果集需要扫描读取的数据行数.

这个值非常直观显示 SQL 的效率好坏, 原则上 rows 越少越好.

(10)extra : EXplain 中的额外信息.

  常见的extra类型    

      a>.using filesort   : 当 Extra 中有 Using filesort 时, 表示 MySQL 需额外的排序操作, 不能通过索引顺序达到排序效果. 一般有 Using filesort, 都建议优化去掉, 因为这样的查询 CPU 资源消耗大

      b>.using  index "覆盖索引扫描", 表示查询在索引树中就可查找所需数据, 不用扫描表数据文件, 往往说明性能不错

      c>.using temporary 查询有使用临时表, 一般出现于排序, 分组和多表 join 的情况, 查询效率不高, 建议优化

参考:

https://www.jianshu.com/p/800560ebc136

         

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 转自:http://blog.chinaunix.net/uid-540802-id-3419311.html e...
    小陈阿飞阅读 1,148评论 0 2
  • Mysql概述 数据库是一个易于访问和修改的信息集合。它允许使用事务来确保数据的安全性和一致性,并能快速处理百万条...
    彦帧阅读 13,725评论 10 460
  • 一、MySQL优化 MySQL优化从哪些方面入手: (1)存储层(数据) 构建良好的数据结构。可以大大的提升我们S...
    宠辱不惊丶岁月静好阅读 2,521评论 1 8
  • 转载:http://blog.codinglabs.org/articles/theory-of-mysql-in...
    qf1007阅读 1,321评论 0 0
  • 念山城 最近越来越怀旧了。上班的路上,收音机里突然蹦出了《十年》,久违而熟悉的旋律瞬间拉回思绪。 十年了,当年毕业...
    君悦我欣阅读 791评论 2 3