explain列有哪些?有什么含义-(explain ref列)

explain列有哪些?有什么含义-(explain ref列)

一、id

SQL查询中的序列号。

id列数字越大越先执行,如果说数字一样大,那么就从上往下依次执行。

二、select_type

explain列有哪些?有什么含义-(explain ref列)

三、table

显示这一行的数据是关于哪张表的。不一定是实际存在的表名。

可以为如下的值:

  • <unionMN>:引用id为M和N UNION后的结果。
  • ;引用id为N的结果派生出的表。派生表可以是一个结果集,例如派生自FROM中子查询的结果。
  • :引用id为N的子查询结果物化得到的表。即生成一个临时表保存子查询的结果。

四、type

这是最重要的字段之一,显示查询使用了何种类型。从最好到最差的连接类型依次为:

system, const, eq_ref, ref, fulltext, ref_or_null, index_merge, unique_subquery,

index_subquery, range, index, ALL

1、 system

表中只有一行数据或者是空表,这是const类型的一个特例。且只能用于myisam和memory表。如果是Innodb引擎表,type列在这个情况通常都是all或者index

2、const

最多只有一行记录匹配。当联合主键或唯一索引的所有字段跟常量值比较时,join类型为const。其他数据库也叫做唯一索引扫描

3、eq_ref

多表join时,对于来自前面表的每一行,在当前表中只能找到一行。这可能是除了system和const之外最好的类型。当主键或唯一非NULL索引的所有字段都被用作join联接时会使用此类型。

eq_ref可用于使用'='操作符作比较的索引列。比较的值可以是常量,也可以是使用在此表之前读取的表的列的表达式。

相对于下面的ref区别就是它使用的唯一索引,即主键或唯一索引,而ref使用的是非唯一索引或者普通索引。

eq_ref只能找到一行,而ref能找到多行。

4、ref

对于来自前面表的每一行,在此表的索引中可以匹配到多行。若联接只用到索引的最左前缀或索引不是主键或唯一索引时,使用ref类型(也就是说,此联接能够匹配多行记录)

ref可用于使用='或<=>操作符作比较的索引列。

5、 fulltext

使用全文索引的时候是这个类型。要注意,全文索引的优先级很高,若全文索引和普通索引同时存在时,mysql不管代价,优先选择使用全文索引

6、ref_or_null

跟ref类型类似,只是增加了null值的比较。实际用的不多。

7、 index_merge

表示查询使用了两个以上的索引,最后取交集或者并集,常见and,or的条件使用了不同的索引、官方排序这个在ref_or_null之后,但是实际上由于要读取多个索引,性能可能大部分时间都不如range

8、unique_subquery

用于where中的in形式子查询,子查询返回不重复值唯一值,可以完全替换子查询,效率更高。该类型替换了下面形式的IN子查询的ref:

value IN (SELECT primary_key FROM single_table WHERE some_expr)

9、 index_subquery

该联接类型类似于unique_subquery。适用于非唯一索引,可以返回重复值。

10、range

索引范围查询,常见于使用 =, <>, >, >=, <, <=, IS NULL, <=>, BETWEEN, IN()或者like等运算符的查询中。

11、index

索引全表扫描,把索引从头到尾扫一遍。这里包含两种情况:

一种是查询使用了覆盖索引,那么它只需要扫描索引就可以获得数据,这个效率要比全表扫描要快,因为索引通常比数据表小,而且还能避免二次查询。在extra中显示Using index,反之,如果在索引上进行全表扫描,没有Using index的提示。

12、all

全表扫描,性能最差。

五、 possible_keys

查询可能使用到的索引都会在这里列出来。

六、Key

key列显示MySQL实际使用的键(索引)

要想强制MvSQL使用或忽视possible kevs列中的索引,可以使用FORCE INDEX、USE INDEX或者IGNORE INDEX。

select_type为index_merge时,这里可能出现两个以上的索引,其他的select_type这里只会出现一个。

七、key_len

表示索引中使用的字节数。

key_len只计算where条件用到的索引长度,而排序和分组就算用到了索引,也不会计算到key_len中。不损失精确性的情况下,长度越短越好。

八、ref

表示上述表的连接匹配条件,即哪些列或常量被用于查找索引列上的值。

九、rows

rows也是一个重要的字段。这是mysql估算的需要扫描的行数(不是精确值)

十、Extra

该列包含MySQL解决查询的详细信息, 有以下几种情况:

  • Using where:列数据是从仅仅使用了索引中的信息而没有读取实际的行动的表返回的,这发生在对表的全部的请求列都是同一个索引的部分的时候,表示mysql服务器将在存储引擎检索行后再进行过滤。
  • Using temporary:表示MySQL需要使用临时表来存储结果集,常见于排序和分组查询。
  • Usingfilesort:MySQL中无法利用索引完成的排序操作称为“文件排序”。
  • Usingjoin buffer:改值强调了在获取连接条件时没有使用索引,并且需要连接缓冲区来存储中间结果。如果出现了这个值,那应该注意,根据查询的具体情况可能需要添加索引来改进能。• Impossible where:这个值强调了where语句会导致没有符合条件的行。
  • Select tables optimized away:这个值意味着仅通过使用索引,优化器可能仅从聚合函数结果中返回一行。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至89291810@qq.com举报,一经查实,本站将立刻删除。
(0)
上一篇 2024年4月15日 上午10:34
下一篇 2024年4月15日 上午10:40

相关推荐

  • 城里孩子不上学

    城里孩子不上学 城里孩子不上学,这是一个令人担忧的问题。在我们的社会中,城市和农村之间的教育水平存在着巨大的差距。城市里的孩子可以享受更好的教育资源和更好的生活条件,而农村的孩子则…

    教育百科 2026年3月2日
  • 要毕业了能休学吗

    要毕业了,能休学吗? 对于许多学生来说,要毕业了是一件令人兴奋的事情,但同时也是一个挑战。即将离开学校,开始职业生涯,但又遇到了一些困难,比如健康问题或个人原因需要休学。这时候,是…

    教育百科 2025年8月11日
  • 早上的太阳(早上的太阳叫什么)

    每当清晨,伴随着阵阵寒风,感受着生命内在的律动,这个时候,总能看到初生的太阳。一开始,初生的太阳,总是那样娇羞,忍不住让人多看几眼,缓缓的,殊不知,这是太阳一天的开始,更是对新生的…

    教育百科 2024年4月29日
  • 浅谈英语需要掌握的11个时态 #英语时态(浅谈英语需要掌握的11个时态有哪些)

    孩子们一般现在是对不对?我们一般是读大师吗?很简单,读大师。三单和非三单是不是读大师?现在进行是什么?读音。b doing是不是?b doing。完成时是什么?have done。…

    教育百科 2024年4月12日
  • 退休学英语生活添乐趣

    退休学英语,生活添乐趣 随着我们年龄的增长,退休已成为不可避免的趋势。然而,在退休之前,我们通常会花费大量时间学习和工作,这使得我们有了充足的时间和精力去学习新的东西。然而,当我们…

    教育百科 2024年6月6日
  • 关注网瘾少年

    关注网瘾少年 网瘾少年是一个让人担忧的群体。他们沉迷于网络,常常忽略现实生活中的重要事情,甚至影响到了他们的学习、工作和人际关系。网瘾少年的问题不仅仅是个人的问题,还涉及到家庭、学…

    教育百科 2026年3月3日
  • 被国外大学休学有影响吗(被国外大学休学)

    我被国外大学休学,这是一个对我来说非常沉重的经历。我曾经对学习充满了热情,希望能够在学术界做出一些成就。但是,当我进入大学后,我发现自己错了。 我的大学是一所著名的大学,但是,它的…

    教育百科 2024年7月12日
  • 活法感悟持之以恒的意思

    活法感悟持之以恒的意思 人生就像一场旅程,有坦途也有坎坷。在这个过程中,我们需要坚持,需要持之以恒。持之以恒并不是指永远坚持某一件事情,而是坚持不懈地去做一件事情,即使在遇到困难和…

    教育百科 2024年10月26日
  • 有理数

    有理数 有理数是一种特殊的数,它可以表示成两个整数的比值。换句话说,一个有理数可以表示为两个整数的商。例如,2/3 是一个有理数,因为它可以表示为 3/2 或 2/3。 有理数在数…

    教育百科 2024年12月11日
  • scum戒掉网瘾

    scum戒掉网瘾的故事 网瘾,是一种可怕的习惯,让人沉迷于虚拟世界,忽略现实生活中的重要性。对于scum来说,上网成瘾已经成为他生活的一部分,但是他意识到,这种习惯会给他带来更多的…

    教育百科 2025年5月28日

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注