MySQL Explain查看执行计划详解

您所在的位置:网站首页 执行计划mysql怎么看 MySQL Explain查看执行计划详解

MySQL Explain查看执行计划详解

2024-07-17 18:57:30| 来源: 网络整理| 查看: 265

目录前言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对待这些表和普通表一样,但是这些“临时表”是没有任何索引的。

type

  type显示的是各个表之间的关联类型,表示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 列显示使用了哪个索引,当使用=、 、>、>=、


【本文地址】

公司简介

联系我们

今日新闻


点击排行

实验室常用的仪器、试剂和
说到实验室常用到的东西,主要就分为仪器、试剂和耗
不用再找了,全球10大实验
01、赛默飞世尔科技(热电)Thermo Fisher Scientif
三代水柜的量产巅峰T-72坦
作者:寞寒最近,西边闹腾挺大,本来小寞以为忙完这
通风柜跟实验室通风系统有
说到通风柜跟实验室通风,不少人都纠结二者到底是不
集消毒杀菌、烘干收纳为一
厨房是家里细菌较多的地方,潮湿的环境、没有完全密
实验室设备之全钢实验台如
全钢实验台是实验室家具中较为重要的家具之一,很多

推荐新闻


    图片新闻

    实验室药品柜的特性有哪些
    实验室药品柜是实验室家具的重要组成部分之一,主要
    小学科学实验中有哪些教学
    计算机 计算器 一般 打孔器 打气筒 仪器车 显微镜
    实验室各种仪器原理动图讲
    1.紫外分光光谱UV分析原理:吸收紫外光能量,引起分
    高中化学常见仪器及实验装
    1、可加热仪器:2、计量仪器:(1)仪器A的名称:量
    微生物操作主要设备和器具
    今天盘点一下微生物操作主要设备和器具,别嫌我啰嗦
    浅谈通风柜使用基本常识
     众所周知,通风柜功能中最主要的就是排气功能。在

    专题文章

      CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭