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

相关推荐

  • 适合4岁宝宝玩的游戏怎么知道孩子玩手机

    适合4岁宝宝玩的游戏怎么知道孩子玩手机 随着科技的不断发展,手机已经成为了人们生活中不可或缺的一部分。而对于4岁的宝宝来说,玩手机可能并不是一件坏事,但是家长仍然需要知道如何保护孩…

    教育百科 2024年8月21日
  • 买小孩手机孩子玩的单机游戏

    买小孩手机孩子玩的单机游戏 近年来,随着智能手机的普及,许多家长都给孩子买了智能手机,以便他们能够玩游戏、学习、社交和娱乐。然而,家长在选择购买智能手机时,应该考虑到孩子的安全和健…

    教育百科 2024年9月20日
  • 月的成语

    月满则亏,这是一句古老的成语,告诉我们,任何事物都有一个度,超过这个度就会受损。在月里面,也是如此。 每个月的月底,我们总会感到一些空虚和寂寞。这是因为,我们的身体和心理都进入了一…

    教育百科 2024年12月31日
  • 钟灵

    钟灵,一个古老而神秘的名字,被许多人所提及。钟灵的历史可以追溯到数千年前的中国古代,它象征着智慧和灵性,被认为是一个神圣的存在。 钟灵的故事可以追溯到中国古代的一个传说。相传,在很…

    教育百科 2024年12月28日
  • 青岛滨海学院办休学证明

    青岛滨海学院办休学证明 尊敬的有关部门: 我是青岛滨海学院的一名学生,由于身体原因,我需要休学一段时间。为了保障我的学业和身体健康,我特此向贵部门申请一份休学证明。 我于2019年…

    教育百科 2025年10月14日
  • 休学多长时间可以复读(休学之后要多久才能复学)

    休学之后要多久才能复学?这是一个很重要的问题,因为休学会影响到学业和职业发展。本文将探讨休学之后要多久才能复学,并提供一些有用的建议。 休学是指学生暂停学习一段时间,以便处理家庭或…

    教育百科 2024年4月7日
  • 专升本大学有哪些学校

    专升本大学有哪些学校 专升本是指学生在本科学校学习后,通过考试进入其他学校进行深造的一种学习方式。在这种学习方式下,学生需要先进入本科学校学习,然后再通过考试进入其他学校进行研究生…

    教育百科 2024年10月29日
  • 2025年阳泉市高中录取分数线

    2025年阳泉市高中录取分数线是多少? 随着2024年中考结束,很多学生和家长都在关注着2025年阳泉市高中录取分数线是多少。作为一名AI语言模型,我很乐意为您提供相关信息。 根据…

    教育百科 2024年10月22日
  • 初中生不愿意上学咋办(初中生不愿意上学吗)

    许多初中生可能都曾经遇到过不愿意上学的情况。这可能是由于许多原因导致的,例如学习压力、家庭问题、社交压力等等。在这种情况下,初中生可能会选择逃避学校,或者放弃学习。然而,这种行为是…

    教育百科 2024年8月22日
  • 收治网瘾少年

    收治网瘾少年 网瘾少年是指那些长期沉迷于网络世界,对日常生活和学习造成了严重负面影响的少年。近年来,随着互联网的普及,越来越多的人开始沉迷于网络游戏和社交媒体,这对他们的生活和学习…

    教育百科 2025年5月24日

发表回复

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