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

相关推荐

  • 立信辅修(立信 休学)

    立信休学:一个大学生的故事 我是一个普通大学生,名叫李华。我曾经在一所著名的高校就读,但是对于我来说,学习并不是我生活的重心。我一直觉得自己的学习成绩不太好,也不喜欢上课,所以一直…

    教育百科 2024年6月21日
  • 2025感恩节是几月几日有什么习俗

    2025年感恩节是几月几日有什么习俗 在这个科技飞速发展的时代,人际关系却似乎变得越来越淡薄。社交媒体上的点赞替代了真实的互动,节日问候也被简短的信息取代。然而,在这个快节奏的生活…

    教育百科 2025年3月27日
  • 过时的网瘾

    过时的网瘾 随着科技的发展,人们的生活方式和工作方式也在不断地变化。然而,有一种旧式的网络成瘾症,却仍然存在于我们的社会中。这种病症被称为“过时的网瘾”。 过时的网瘾是指那些在网络…

    教育百科 2025年6月29日
  • 网瘾防范

    网瘾防范 随着互联网的普及和发展,越来越多的人开始沉迷于网络世界,这种现象被称为“网瘾”。网瘾不仅会对身心健康造成负面影响,还会对社会和家庭造成严重的影响。因此,网瘾防范已经成为了…

    教育百科 2025年10月11日
  • 孤芳自赏什么意思

    孤芳自赏是一个汉语成语,意思是指一个人独自欣赏自己的美貌或才华,而不愿意与他人分享。这个成语常常用来形容那些自我陶醉、孤立自我的人,他们似乎认为自己的美貌或才华是独一无二的,不愿意…

    教育百科 2025年1月6日
  • 孩子爱玩手机的原因小孩儿爱玩手机

    孩子爱玩手机的原因 近年来,随着智能手机和平板电脑的普及,孩子们越来越流行玩手机游戏。孩子们为什么会喜欢玩手机呢?以下是一些可能的原因: 1. 社交互动:许多手机游戏都有社交功能,…

    教育百科 2024年9月28日
  • 高三休学

    高三休学,是一个让人深思的决定。在高中的最后一个学期,对于很多人来说都是一个关键的时期,因为这将是他们人生中的一个重要转折点。然而,高三休学却成为了我的决定。 我为什么要休学呢?对…

    教育百科 2025年8月12日
  • 怎么测试自己是否有抑郁症

    抑郁症是一种常见的心理疾病,它可能会影响一个人的情绪,思维,和行为。如果你认为自己可能患有抑郁症,那么测试自己是否有抑郁症是很重要的。以下是一些测试自己是否有抑郁症的方法: 1. …

    教育百科 2025年11月1日
  • 焦作师专在市中心吗

    焦作师专在市中心吗? 提到焦作市,许多人可能只知道它是河南省的一个地级市,但却不知道它的市中心是谁。然而,对于焦作师专的学生和工作人员来说,市中心是他们的学校和工作场所。因此,对于…

    教育百科 2024年12月1日
  • 杨广是昏君吗

    杨广是昏君吗? 杨广,是中国历史上的一位著名皇帝,他在位期间,经历了许多政治和军事上的改革,但也有一些争议和批评。 杨广的在位期间,曾经实行过一些重要的政治和军事改革,例如推行“广…

    教育百科 2024年12月12日

发表回复

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