MySQL Explain查看执行计划详解 |
您所在的位置:网站首页 › 执行计划mysql怎么看 › MySQL Explain查看执行计划详解 |
目录前言EXPLAIN 中的列id 和select_typetabletypepossible_keyskey 和 key_lenref 和 rowsExtra小结Reference
前言
什么是执行计划?简而言之,就是 SQL 在数据库中执行时的表现情况,通常用于 SQL 性能分析、优化和加锁分析等场景,执行过程会在 MySQL 查询过程中由解析器,预处理器和查询优化器共同生成。在MySQL中使用 explain 关键字来查看。 执行计划能告诉我们什么?她可以用来分析SQL语句和表结构的性能瓶颈。通过分析explain的输出结果集,可以了解到诸如关联查询的执行顺序、查询操作的操作类型、哪些索引可以被命中、哪些索引实际被命中、每张表有多少记录参与查询等信息。接下来,我们将介绍在explain结果集中每一列的意义。 EXPLAIN 中的列 mysql> explain select * from servers; +----+-------------+---------+------+---------------+------+---------+------+------+-------+ | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | +----+-------------+---------+------+---------------+------+---------+------+------+-------+ | 1 | SIMPLE | servers | ALL | NULL | NULL | NULL | NULL | 1 | NULL | +----+-------------+---------+------+---------------+------+---------+------+------+-------+ 1 row in set (0.03 sec)expain执行后输出的结果集包含10列,分别是id、select_type、table、type、possible_keys、key、key_len、ref、rows和Extra,下面对这些字段进行解释。 列名 说明 id 执行编号,标识select所属的行。如果在语句中没子查询或关联查询,只有唯一的select,每行都将显示1。否则,内层的select语句一般会顺序编号,对应于其在原始语句中的位置 select_type 显示本行是简单或复杂select。如果查询有任何复杂的子查询,则最外层标记为PRIMARY(DERIVED、UNION、UNION RESUlT) table 访问引用哪个表(引用某个查询,如“derived3”) type 数据访问/读取操作类型(ALL、index、range、ref、eq_ref、const/system、NULL) possible_keys 揭示哪一些索引可能有利于高效的查找 key 显示mysql决定采用哪个索引来优化查询 key_len 显示mysql在索引里使用的字节数 ref 显示了之前的表在key列记录的索引中查找值所用的列或常量 rows 为了找到所需的行而需要读取的行数,估算值,不精确。通过把所有rows列值相乘,可粗略估算整个查询会检查的行数 Extra 额外信息,如using index、filesort等 id 和select_type每个被独立执行的操作的标识,表示各个SQL片段被操作的顺序;在嵌套查询中id越大的语句越先执行,如果相同,那么按照从上到下的顺序执行。该值可能为NULL,如果这一行用来说明的是其他行的联合结果。 -- 查看在研发部并且名字以Jef开头的员工,经典查询 explain select e.no, e.name from emp e left join dept d on e.dept_no = d.no where e.name like 'Jef%' and d.name = '研发部';select_type表示查询的类型,其枚举值和说明见下表: 类型 说明 simple 简单SELECT,不包含子查询和union primary 包含union或者子查询,最外层的部分标记为primary subquery 一般子查询中的子查询被标记为subquery,也就是位于select列表中的查询 derived 派生表——该临时表是从子查询派生出来的,位于from中的子查询 union 位于union中第二个或者其以后的子查询被标记为union,第一个就被标记为primary。若union位于from中,则标记为derived。取决于外面的查询 union result 用来从匿名临时表里检索结果的select子句被标记为union result dependent union 顾名思义,首先需要满足UNION的条件,及UNION中第二个以及后面的SELECT语句,同时该语句依赖外部的查询 subquery 子查询中第一个SELECT语句 dependent subquery 子查询中的第一个 select,取决于外侧的查询,一般是 in 中的子查询。该示例中,in子查询的select_type被标记为dependent subquery ,主查询被标记为primary。 此图展示了 union 和 union result 的 SQL 案例。 table对应行正在访问哪一个表,可以是表名或者别名 关联优化器会为查询选择关联顺序,左侧深度优先 当from中有子查询的时候,表名是derivedN的形式,N指向子查询,也就是explain结果中的下一列 当有union result的时候,表名是union 1,2等的形式,1,2表示参与union的query id注意:MySQL对待这些表和普通表一样,但是这些“临时表”是没有任何索引的。 typetype显示的是各个表之间的关联类型,表示MySQL决定如何查找表中的记录。是最重要的一个指标,其性能从高到低依次是: system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL 一般来说,得保证查询至少达到range级别,最好能达到ref;否则,就可能会出现性能问题。 类型 说明 All 最坏的情况,全表扫描 index 和全表扫描一样,只是扫描表的时候按照索引次序进行而不是行。主要优点就是避免了排序, 但是开销仍然非常大。如在Extra列看到Using index,说明正在使用覆盖索引,只扫描索引的数据,它比按索引次序全表扫描的开销要小很多 range 根据索引检查给定范围的行。key 列显示使用了哪个索引,当使用=、 、>、>=、 |
今日新闻 |
点击排行 |
|
推荐新闻 |
图片新闻 |
|
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭 |