首页
学习
活动
专区
圈层
工具
发布

MySQL Explain用法详解

output 列名 备注 id select的编号,从1开始,如果是没有子查询,则编号为1,如果有子查询,则最外侧的select为1,然后按照select的顺序从左到右逐渐递增 select_type...查询类型,例如简单查询,子查询,Union查询等(具体见下表) table select所访问的表(也可以是派生表) partitions 用于分区表, 表示select所访问的表的分区 type 表示该...possible_keys 表示可能会用到的索引用来加速查询,未经过优化器确定。 key 经过优化器确定之后,实际采用的索引 key_len 实际采用的索引的字段长度....(计算方式与字符集、字段类型是否为固定长度以及是否可以为null有关系) ref 表示key在查找数据的时候,所用到的常量或者列名 rows 查询所扫描的行数,但是一般不准确。...ref可以用于使用=或操作符的带索引的列.或者仅查询主键,并且condition里面使用索引。

1.3K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql explain用法和结果的含义

    explain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。...使用方法,在select语句前加上explain就可以了: 先看个例子 mysql> explain select * from t_order;  | id | select_type | table...ALL:对于每个来自于先前的表的行组合,进行完整的表扫描。 possible_keys 指出MySQL能使用哪个索引在该表中找到行 key 显示MySQL实际决定使用的键(索引)。...Extra 该列包含MySQL解决查询的详细信息 Distinct:MySQL发现第1个匹配行后,停止为当前的行组合搜索更多的行。...Extra 该列包含MySQL解决查询的详细信息 Distinct:MySQL发现第1个匹配行后,停止为当前的行组合搜索更多的行。

    2.5K10

    Mysql中explain用法和结果字段的含义介绍

    做一个积极的人 编码、改bug、提升自己 我有一个乐园,面向编程,春暖花开 文章目录 explain用法 explain结果字段的含义介绍 id select_type table type possible_keys...explain用法 mysql> explain select * from students; +----+-------------+----------+------+--------------...Extra 该列包含MySQL解决查询的详细信息 Distinct:MySQL发现第1个匹配行后,停止为当前的行组合搜索更多的行。...不会告诉你关于触发器、存储过程的信息或用户自定义函数对查询的影响情况 EXPLAIN不考虑各种Cache EXPLAIN不能显示MySQL在执行查询时所作的优化工作 部分统计信息是估算的,并非精确值 EXPALIN...参考博文 mysql中explain用法和结果的含义 EXPLAIN 命令详解 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/121081.html原文链接:https

    1K40

    mysql的explain详解

    我们在实际业务中经常会使用到explain,因为这里涉及到查询,下面我们来看一个例子,比如我们要查一本书的上一章或者下一章,我们的sql是这样: 查询5164这本书4054495这一章的上一章:下面的是...500多万条数据,我explain了一下: explain SELECT * FROM article WHERE (id mysql的查询,更多是注重扫描查询的行数,以及是否使用到索引,我常看的最重要的是扫描的rows字段,然后就key字段,看下extra的属性,这样就基本能解决问题了。...字段:possible_keys 解释:可能用到的索引 字段:key 解释:实际用到的索引 常见值及其说明: MySQL决定实际用到的索引,显示的是索引的名称,多个索引用逗号隔开,如果没有 ,则为null...using temporary:mysql需要创建一张临时表来保存中间结果。也就是说,需要先把数据放到临时表中,然后从临时表中获取需要的数据。

    55430

    MySQL EXPLAIN 的使用

    EXPLAIN列的解释: table:显示这一行的数据是关于哪张表的 type:这是重要的列,显示连接使用了何种类型。...很少的情况下,MYSQL会选择优化不足的索引。...在不损失精确性的情况下,长度越短越好 ref:显示索引的哪一列被使用了,如果可能的话,是一个常数 rows:MYSQL认为必须检查的用来返回请求数据的行数 Extra:关于MYSQL如何解析查询的额外信息...:一旦MYSQL找到了与行相联合匹配的行,就不再搜索了 Not exists: MYSQL优化了LEFT JOIN,一旦它找到了匹配LEFT JOIN标准的行,就不再搜索了 Range checked...因为只有一行,这个值实际就是常数,因为MYSQL先读这个值然后把它当做常数来对待 eq_ref:在连接中,MYSQL在查询时,从前面的表中,对每一个记录的联合都从表中读取一个记录,它在查询使用了索引为主键或惟一键的全部时使用

    61310

    Mysql Explain的主要字段

    这可能是除了system和const之外最好的类型。 当主键或唯一非NULL索引的所有字段都被用作join联接时会使用此类型。 eq_r ef可用于使用’='操作符作比较的索引列。...比较的值可以是常量,也可以是使用在此表之前读取的表的列的表达式。 相对于下面的ref区别就是它使用的唯一索引,即主键或唯一索引,而ref使用的是非唯一索引或者普通索引。...4、ref 对于来自前面表的每一行,在此表的索引中可以匹配到多行。若联接只用到索引的最左前缀或索引不是主键或唯一索引时, 使用ref类型(也就是说,此联接能够匹配多行记录)。...要注意,全文索引的优先级很高,若全文索引和普通索引同时存在时,mysql不管代价,优先选择使用全文索引 6、ref_or_null 跟ref类型类似,只是增加了null值的比较。实际用的不多。...这里包含两种情况: 一种是查询使用了覆盖索引,那么它只需要扫描索引就可以获得数据,这个效率要比全表扫描要快, 12ALl 没有使用索引,全表扫描 12. extra(重要)     EXplain

    1.8K20

    关于Mysql的explain工具

    当你运行一条sql执行很慢的时候,可以使用explain sql,"explain"相当于mysql中的优化器,可以很好的分析性能瓶颈。 ?...如上图,就是explain的执行效果,查询出很多字段,我们主要关注其中比较重要的几个 type:访问的类型,性能从高到低NULL>system>const>eq_ref>ref>fulltext>ref_or_null...unique_subquery>index_subquery>range>index>ALL const:通过索引一次就找到,用到了主键或唯一索引,匹配一行所以很快 index_merge:索引合并的优化方法...range:使用指定范围的行语句出现between、、in等 index:只遍历索引树查询 all:全表查询 key:使用到的索引 rows:找到结果所需要读取的行 官网的解释:https...://dev.mysql.com/doc/refman/8.0/en/explain-output.html#explain-join-types

    49430

    mysql explain ref列_MySQL EXPLAIN详解

    MySQL EXPLAIN详解:http://www.jianshu.com/p/ea3fc71fdc45 MySQL EXPLAIN命令是查询性能优化不可缺少的一部分,该文主要讲解explain...,N指向子查询,也就是explain结果中的下一列 当有union result的时候,表名是union 1,2等的形式,1,2表示参与union的query id 注意:MySQL对待这些表和普通表一样...Extra Extra是EXPLAIN输出中另外一个很重要的列,该列显示MySQL在查询过程中的一些详细信息,MySQL查询优化器执行查询的过程中对查询计划的重要补充信息。...distinct 优化distinct操作,在找到第一匹配的元组后即停止找同样值的动作 explain的作用 我们使用explain命令来查看mysql语句的执行计划(execution plan),解释...用法 只需要在sql语句前加上explain就可以了,比如: +—-+————-+——-+————+——+—————+——+———+——+——–+———-+——-+ | id | select_type

    4.7K60

    谈谈MYSQL中的Explain

    前言我们在设计一个系统的时候,有时候通常为了基础业务,写出的查询sql语句并不高效,从而影响到用户使用系统的整体体验感不是很好,我们通常在系统的测试阶段会开启MySQL中的慢日志查询的功能,可以在MySQL...了,从而就可以对这些语句进行调优优化,使用 Explain来分析 SQL 语句的性能。...=3#慢查询日志以文件的形式输出log_output=FILE基本介绍 Explain被称为执行计划,在语句之前增加 explain 关键字,MySQL 会在查询上设置一个标记,模拟MySQL优化器来执行...Explain结果是基于数据表中现有数据的。Explain结果与MySQL版本有很大的关系,不同版本的优化器的优化策略不同。...语法:explain sql语句示例:mysql> explain select * from actor;+----+-------------+-------+------+------------

    54021

    mysql explain ref null_MySQL Explain详解

    MySQL Explain详解 简介 执行计划(query Execution plan) 语法 explain select * from table explain 中的列 expain出来的信息有...通常,您可以ALL通过添加基于常量值或早期表中的列值从表中启用行检索的索引来避免 五、possible_keys 该possible_keys列指示MySQL可以选择在此表中查找行的索引,指出MySQL...能使用哪个索引在表中找到记录,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 该列完全独立于EXPLAIN输出所示的表的次序。...如果是这样,创造一个适当的索引并且再次用EXPLAIN检查查询 六、Key key列显示MySQL实际决定使用的键(索引) 如果没有选择索引,键是NULL。...十、Extra 该Extra列 EXPLAIN输出包含MySQL解决查询的额外信息。

    2.3K40

    mysql explain详解

    Explain简介 本文主要讲述如何通过 explain 命令获取 select 语句的执行计划,通过 explain 我们可以知道以下信息:表的读取顺序,数据读取操作的类型,哪些索引可以使用,哪些索引实际使用了...下面是使用 explain 的例子: 在 select 语句之前增加 explain 关键字,MySQL 会在查询上设置一个标记,执行查询时,会返回执行计划的信息,而不是执行这条SQL(如果 from...explain 中的列 接下来我们将展示 explain 中每个列的信息。...MySQL会将结果存放在一个临时表中,也称为派生表(derived的英文含义) 用这个例子来了解 primary、subquery 和 derived 类型 mysql> explain select...常见的重要值如下: distinct: 一旦mysql找到了与行相联合匹配的行,就不再搜索了 mysql> explain select distinct name from film left join

    41.7K2322

    MySQL EXPLAIN ANALYZE

    Ryeng 译:徐轶韬 MySQL8.0.18刚刚发布,它包含一个全新的功能EXPLAIN ANALYZE,用来分析和理解查询如何执行。 EXPLAIN ANALYZE是什么?...EXPLAIN ANALYZE是一个用于查询的分析工具,它向用户显示MySQL在查询上花费的时间以及原因。它将产生查询计划,并对其进行检测和执行,同时计算行数并度量执行计划中不同点上花费的时间。...这项新功能建立在常规的EXPLAIN基础之上,可以看作是MySQL 8.0之前添加的EXPLAIN FORMAT = TREE的扩展。...EXPLAIN除了输出查询计划和估计成本之外,EXPLAIN ANALYZE还会输出执行计划中各个迭代器的实际成本。 如何使用?...EXPLAIN ANALYZE是MySQL查询分析工具里面的一个新工具: 检查查询计划:EXPLAIN FORMAT = TREE 分析查询执行:EXPLAIN ANALYZE 了解计划选择:Optimizer

    1.6K20

    【mysql】explain介绍

    我们对系统性能分析的一部分就是数据库的分析,比如定位到查询速度慢的SQL,我们想对其进行优化,但是从哪些方面进行优化,就需要使用explain来查看select语句的执行计划。...explain关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理SQL语句的,对我们的查询语句进行分析,提升性能。...使用expain关键字,我们可以分析到的信息有: 表的读取顺序 数据读取操作的操作类型 哪些索引可以使用 哪些索引被实际使用 表之间的引用 每张表有多少行被优化器查询 使用方法:explain + SQL...SUBQUERY 在SELECT或WHERE列表中包含了子查询 DERIVED 在FROM列表中包含的子查询被标记为DERIVED(衍生),MySQL会递归执行这些子查询,把结果放在临时表中...如将主键置于where列表中,MySQL就能将该查询转换为一个常量。

    58830
    领券