MySQL EXPLAIN 完全解读

MySQL EXPLAIN 完全解读

  • 一、一个EXPLAIN简单执行
  • 二、简单了解
    • 2.1. id:查询的标识符。
    • 2.2. select_type:查询的类型。
    • 2.3. table:输出结果集的表。
    • 2.4. type:连接类型,这是MySQL决定如何查找表中行的方法。
    • 2.5. possible_keys:可能用到的索引。
    • 2.6. key:实际使用的索引。
    • 2.7. key_len:使用的索引的长度。
    • 2.8. ref:显示索引的哪一部分被使用了
    • 2.9. rows:MySQL认为必须检查的用来获取查询结果的行数。
    • 2.10. Extra:包含MySQL解决查询的详细信息。
  • 三、重点讲解
    • 3.1、SELECT_TYPE列表示MySQL如何查找表中的行。
    • 3.2、type列表示MySQL如何查找表中的行。
      • 3.2.1、一些常见的值及其含义
      • 3.2.2、一些例子
    • 3.3、EXPLAIN命令的key列用于显示MySQL在查询中使用的键(索引)
      • 3.3.1、NULL:MySQL 没有使用任何键(索引)进行查询。
      • 3.3.2、索引名称:如果 MySQL 使用了某个索引进行查询,那么 key 的值就是那个索引的名称。
      • 3.3.3、PRIMARY:如果 MySQL 使用了主键索引进行查询,那么 key 的值就是 PRIMARY。
    • 3.4、key_len列在MySQL的EXPLAIN输出中表示的是MySQL在索引中使用的字节数
    • 3.5、ref 列显示了MySQL如何使用索引来查找数据
    • 3.6、Extra列提供了关于查询执行方式的额外信息

一、一个EXPLAIN简单执行

在这里插入图片描述

二、简单了解

在MySQL中,EXPLAIN语句用于获取关于如何执行SQL语句的信息。以下是EXPLAIN输出的各个列的含义:

2.1. id:查询的标识符。

如果一个查询包含子查询,那么每个子查询都会有一个不同的id。

2.2. select_type:查询的类型。

这个列的值可以是SIMPLE(简单查询,不包含子查询或者UNION)、PRIMARY(查询中最外层的查询)、SUBQUERY(子查询中的第一个SELECT)、DERIVED(派生表的查询,MySQL会先执行这个查询,然后把结果放在临时表中)等。

2.3. table:输出结果集的表。

2.4. type:连接类型,这是MySQL决定如何查找表中行的方法。

常见的值有const、eq_ref、ref、range、index和ALL。

2.5. possible_keys:可能用到的索引。

2.6. key:实际使用的索引。

2.7. key_len:使用的索引的长度。

在不损失精度的情况下,长度越短越好。

2.8. ref:显示索引的哪一部分被使用了

如果可能的话,会显示哪个列或常数被用于查找索引列。

2.9. rows:MySQL认为必须检查的用来获取查询结果的行数。

2.10. Extra:包含MySQL解决查询的详细信息。

常见的值有Using index(表示MySQL只用到了索引,没有去读取实际的行,Using where(表示MySQL使用了WHERE过滤器)等。

三、重点讲解

3.1、SELECT_TYPE列表示MySQL如何查找表中的行。

SELECT_TYPE 是 MySQL 中 EXPLAIN 命令的输出列之一,用于描述查询中每个 SELECT 子句的类型。以下是一些可能的 SELECT_TYPE 值及其含义:

  1. SIMPLE:简单 SELECT(不使用 UNION 或子查询等)。
SELECT * FROM table1;
  1. PRIMARY:查询中如果包含任何复杂的子部分,最外层的 SELECT 被标记为 PRIMARY。
SELECT * FROM table1 WHERE id IN (SELECT id FROM table2);
  1. SUBQUERY:在 SELECT 或 WHERE 列表中的第一个 SELECT 子查询。
SELECT * FROM table1 WHERE id IN (SELECT id FROM table2);
  1. DERIVED:在 FROM 列表中的子查询。
SELECT * FROM (SELECT id FROM table2) AS derived_table;
  1. UNION:如果第二个或后续的 SELECT 是 UNION 的一部分,则 SELECT_TYPE 是 UNION。
SELECT column1 FROM table1 UNION SELECT column2 FROM table2;
  1. UNION RESULT:从 UNION 表中选择结果的 SELECT。
(SELECT column1 FROM table1 UNION SELECT column2 FROM table2) ORDER BY 1;

3.2、type列表示MySQL如何查找表中的行。

3.2.1、一些常见的值及其含义

  1. const:这是最好的一种连接类型,表示MySQL能够在索引中一次就找到相关的行。这通常发生在你执行主键或唯一索引的查询,并且只返回一行结果的情况下。
  2. eq_ref:这是第二好的连接类型,表示MySQL在连接表时,对于每一行都只需要读取一次,这通常发生在你使用主键或唯一索引的情况下。
  3. ref:这种连接类型表示MySQL需要对每个外键组合执行一次查找,这通常发生在你使用非唯一索引或者非主键的情况下。
  4. range:这种连接类型表示MySQL在索引中进行范围查找,这通常发生在你使用BETWEEN、<、>、IS NULL或者IN等操作符的情况下。
  5. index:这种连接类型表示MySQL进行全索引扫描,这通常发生在你的查询只需要从索引中获取数据,而不需要查看实际的行数据的情况下。
  6. ALL:这是最差的连接类型,表示MySQL需要进行全表扫描,这通常发生在你的查询没有使用到索引的情况下。

3.2.2、一些例子

假设我们有一个名为users的表,其中包含id(主键)、name和email(唯一索引)三个字段。

  1. 如果我们执行查询SELECT * FROM users WHERE id = 1,那么type列的值就是const,因为MySQL可以通过主键一次就找到相关的行。
  2. 如果我们执行查询SELECT * FROM users WHERE email = 'example@example.com',那么type列的值就是ref,因为MySQL需要对每个外键组合执行一次查找。
  3. 如果我们执行查询SELECT * FROM users WHERE id BETWEEN 1 AND 1000,那么type列的值就是range,因为MySQL在索引中进行范围查找。
  4. 如果我们执行查询SELECT id FROM users ORDER BY id,那么type列的值就是index,因为MySQL进行全索引扫描。
  5. 如果我们执行查询SELECT * FROM users,那么type列的值就是ALL,因为MySQL需要进行全表扫描。

3.3、EXPLAIN命令的key列用于显示MySQL在查询中使用的键(索引)

3.3.1、NULL:MySQL 没有使用任何键(索引)进行查询。

EXPLAIN SELECT * FROM table1 WHERE non_indexed_column = 'value';

在这个例子中,non_indexed_column 是一个没有索引的列,所以 key 的值为 NULL。

3.3.2、索引名称:如果 MySQL 使用了某个索引进行查询,那么 key 的值就是那个索引的名称。

EXPLAIN SELECT * FROM table1 WHERE indexed_column = 'value';

在这个例子中,indexed_column 是一个有索引的列,所以 key 的值就是该列的索引名称。

3.3.3、PRIMARY:如果 MySQL 使用了主键索引进行查询,那么 key 的值就是 PRIMARY。

EXPLAIN SELECT * FROM table1 WHERE id = 1;

3.4、key_len列在MySQL的EXPLAIN输出中表示的是MySQL在索引中使用的字节数

这个值是根据索引类型和索引字段的类型以及长度计算出来的。
例如,对于一个CHAR(10)类型的字段,如果它是一个字符串类型的索引,那么key_len的值就是10。如果这个字段是一个整数类型的索引,那么key_len的值就是4(因为整数类型的索引的长度是4字节)。 需要注意的是,key_len并不一定等于索引字段的实际长度。例如,对于一个VARCHAR(100)类型的字段,即使它的最大长度是100,但如果在查询中只使用了前10个字符,那么key_len的值就是10。 总的来说,key_len可以帮助你理解MySQL如何使用索引,以及索引的效率。在不损失精度的情况下,key_len的值越小,表示使用的索引越精简,查询效率可能会更高。

3.5、ref 列显示了MySQL如何使用索引来查找数据

例如,假设我们有一个名为 users 的表,其主键为 id,并且有一个名为 email 的唯一索引。以下是一些可能的情况:

  1. 使用主键进行查询:
EXPLAIN SELECT * FROM users WHERE id = 1;

在这个例子中,EXPLAIN 的输出可能会显示 ref 列的值为 const,表示我们使用了一个常量值(在这种情况下是 1)来查找主键索引。
2. 使用唯一索引进行查询:

EXPLAIN SELECT * FROM users WHERE email = 'user@example.com';

在这个例子中,EXPLAIN 的输出可能会显示 ref 列的值为 const,表示我们使用了一个常量值(在这种情况下是 ‘user@example.com’)来查找 email 索引。
3. 使用非唯一索引进行查询:
假设 users 表有一个非唯一索引 status,我们可以执行以下查询:

EXPLAIN SELECT * FROM users WHERE status = 'active';

在这个例子中,EXPLAIN 的输出可能会显示 ref 列的值为 const,表示我们使用了一个常量值(在这种情况下是 ‘active’)来查找 status 索引。
请注意,ref 列的值并不总是 const。如果我们使用了一个列的值来查找索引,那么 ref 列的值就会是那个列的名称。例如,如果我们有一个查询 SELECT * FROM users u JOIN orders o ON u.id = o.user_id,那么 EXPLAIN 的输出可能会显示 ref 列的值为 o.user_id,表示我们使用了 orders 表的 user_id 列的值来查找 users 表的主键索引。

3.6、Extra列提供了关于查询执行方式的额外信息

以下是一些可能出现在Extra列中的值及其含义:
1.Using index:这表示MySQL只需要读取索引,而不需要读取数据行。这通常发生在所有需要的数据列都包含在索引中的情况下。
2.Using where:这表示MySQL服务器将在存储引擎检索行后再进行过滤。这可能意味着存储引擎无法执行全部的过滤工作,可能是因为查询的某部分没有被索引覆盖。
3.Using temporary:这表示MySQL需要创建一个临时表来存储结果,这通常发生在对不同的列进行ORDER BY和GROUP BY的情况下。
4.Using filesort:这表示MySQL会对结果使用一个外部索引排序,而不是按照表中的索引顺序进行读取。这通常发生在ORDER BY或GROUP BY的列不是索引的一部分的情况下。
5.Range checked for each record (index map: N):这表示MySQL无法确定使用哪个索引,所以对于每一行数据,它都会检查是否可以使用索引。
6.Impossible WHERE noticed after reading const tables:这表示WHERE子句的条件总是false,当检查到这一点时,查询已经不再继续。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/52647.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大语言模型-GPT3-Language Models are Few-Shot Learners

一、背景信息&#xff1a; GPT3是于2020 年由OpenAI 发布的预训练语言模型。 GPT3在自然语言处理&#xff08;NLP&#xff09;任务中表现出色&#xff0c;可以生成连贯的文本、回答问题、进行对话等。 GPT3的网络架构继续沿用GPT1、GPT2的是多层Transformer Decoder改的结构。…

大数据技术之Flume 企业开发案例——自定义 Sink(10)

目录 自定义 Sink 1&#xff09;介绍 2&#xff09;需求 3&#xff09;编码 4&#xff09;测试 自定义 Sink 1&#xff09;介绍 Sink 不断地轮询 Channel 中的事件并批量地移除它们&#xff0c;随后将这些事件批量写入到存储或索引系统&#xff0c;或者发送到另一个 Flu…

jenkins 开启控制台详细日志

1、开启控制台详细日志&#xff0c;查看真正报错原因 开启后生成流水线语句&#xff1a; 2、根本问题 使用jenkins再次构建&#xff0c;查看控制台日志 报错&#xff1a; 意思是在执行ssh命令的时候&#xff0c; /root/apps/jenkins/portal/portal-server/Dockerfile 路径下没…

极狐GitLab 如何管理 Kubernetes 集群?

极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门面向中国程序员和企业提供企业级一体化 DevOps 平台&#xff0c;用来帮助用户实现需求管理、源代码托管、CI/CD、安全合规&#xff0c;而且所有的操作都是在一个平台上进行&#xff0c;省事省心省钱。可以一键安装极狐GitL…

【计算机网络】电路交换、报文交换、分组交换

电路交换&#xff08;Circuit Switching&#xff09;&#xff1a;通过物理线路的连接&#xff0c;动态地分配传输线路资源 ​​​​

《机器学习》 SVM支持向量机 推导、参数解析、可视化实现

目录 一、SVM支持向量机 1、什么是SVM 例如&#xff1a; 2、SVM的主要特点是&#xff1a; 二、SVM方程 1、超平面方程 2、标签问题 3、决策函数&#xff1a; 符号函数&#xff1a; 整合&#xff1a; 4、距离问题 1&#xff09;点到直线距离 2&#xff09;点到平面…

关于喷墨打印:液滴喷射及基材影响的那些事儿

大家好&#xff0c;今天我们来探讨一篇关于液滴喷射在生物应用中相关知识的文章——《Understanding droplet jetting on varying substrate for biological applications》是发表于《International Journal of Bioprinting》。在生物打印领域&#xff0c;了解液滴在不同基材上…

【Pytorch】Linear 层,举例:相机参数和Instance Feaure通过Linear层生成Group Weights

背景 看论文看到这个pipeline&#xff0c;对于相机参数和Instance Fature 的融合有点兴趣&#xff0c;研究如下&#xff1a; Linear 层 Linear 层是最基本的神经网络层之一&#xff0c;也称为全连接层。它将输入与每个输出神经元完全连接。每个连接都有一个权重和一个偏置。…

elasticsearch快照存储到linux本地路径或分布式存储系统mioio

一、使用linux本地目录做快照存储 1.编辑 elasticsearch.yml 文件&#xff0c;添加以下配置&#xff1a; path.repo: ["/path/to/your/backup/dir"]2.创建一个文件系统类型的快照仓库 PUT /_snapshot/my_local_repository {"type": "fs",&quo…

磷酸二氢钾溶液净化除杂,除重金属

磷酸二氢锂&#xff0c;化学式LiH2PO4&#xff0c;相对分子质量103.93&#xff0c;白色结晶或粉末。熔点大于100℃&#xff0c;相对密度2.5g/ml。每100毫升水中的溶解克数&#xff1a;126g/0℃。 锂离子二次电池在手提电脑、移动通讯、电动工具等方面具有广泛应用&#xff0c;在…

使用VScode的Git版本控制功能(图文版)

☁️ 前言 今天让我来手把手教你简单入门VScode自带的Git版本控制。 &#x1f389; 初始化仓库 初始化仓库之后&#xff0c;仓库里的文件发生了任何改动都会有相应的提示&#xff0c;这对于我们开发和维护项目非常有帮助。 &#x1f389;提交更改 初始化仓库之后&#xff…

基于web的停车场管理系统设计与实现-计算机毕设 附源码 16856

基于web的停车场管理系统设计与实现 目 录 1 绪论 1.1 研究背景和意义 1.2国内外研究现状 1.3论文结构与章节安排 2 系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 操作可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能性分…

【自动化】考试答题自动化完成答案,如何实现100%正确呢

一、科目仿真考试不能自动答题 我的答案是可以的&#xff0c;电脑程序可以模拟人的操作完成所有的答题并提交结束考试 二、分析页面内容 完成一个题目&#xff0c;包括判断题&#xff0c;对与错2选1答案&#xff0c;单选题ABCD4选1答案&#xff0c;多选题大家想一想 F12查看按…

基于layui实现简单的万智牌生命计数器页面

对照手机App“旅法师营地”的万智牌生命计数器窗口&#xff08;如下图所示&#xff09;&#xff0c;使用layui、jQuery等实现简单的万智牌生命计数器页面。   主要实现的功能如下&#xff1a;   1&#xff09;点击左右两侧的-1、1、-5、5区域更新左右两侧生命值&#xff1…

【MATLAB学习笔记】绘图——自定义标记(Marker)形状,实现与MATLAB自带标记基本一致的功能(自适应缩放、自适应裁剪)

目录 前言自定义标记函数自定义标记函数的说明纵横比调整将图形大小按磅数设置平移标记点绘制标记点边界标记点不裁剪 拓展功能——标记点自适应绘图区的缩放绘图区缩放回调函数标记点大小自适应标记点裁剪自适应 示例基本绘图自定义标记函数的使用 总代码主函数自定义标记函数…

入门STM32--按键输入

上一篇博客我们介绍了如何使用GPIO配置跑马灯&#xff0c;根据GPIO的基本结构图&#xff0c;我们能够发现&#xff0c;他肯定不单单有输出的功能&#xff0c;肯定可以检测IO上的电平变化&#xff0c;实际上就是输入的功能。 1.按键 在大多数情况下&#xff0c;按键是一种简单的…

【第54课】XSS跨站Cookie盗取表单劫持网络钓鱼溯源分析项目平台框架

免责声明 本文发布的工具和脚本&#xff0c;仅用作测试和学习研究&#xff0c;禁止用于商业用途&#xff0c;不能保证其合法性&#xff0c;准确性&#xff0c;完整性和有效性&#xff0c;请根据情况自行判断。 如果任何单位或个人认为该项目的脚本可能涉嫌侵犯其权利&#xff0…

1259:【例9.3】求最长不下降序列 动态规划

1259&#xff1a;【例9.3】求最长不下降序列 题目链接 【输入样例】 【输入样例】 14 13 7 9 16 38 24 37 18 44 19 21 22 63 15【输出样例】 max8 7 9 16 18 19 21 22 63思路&#xff1a; 确定状态&#xff1a; a[n]数组放数据&#xff0c; dp[n]数组放第i个位子前最长子序…

kafka发送消息-生产者发送消息的分区策略(消息发送到哪个分区中?是什么策略)

生产者发送消息的分区策略&#xff08;消息发送到哪个分区中&#xff1f;是什么策略&#xff09; 1、默认策略&#xff0c;程序自动计算并指定分区1.1、指定key&#xff0c;不指定分区1.2、不指定key&#xff0c;不指定分区 2、轮询分配策略RoundRobinPartitioner2.1、创建配置…

Linux网络:网络基础

Linux网络&#xff1a;网络基础 一、网络诞生背景及产生的诸多问题1. 1 网络诞生背景1.2 网络诞生面临的困境 二、网络协议栈&#xff08;OSI七层模型、CP/IP五层模型&#xff09;2.1 TCP/IP五层(或四层)模型 三、网络和系统关系四、网络传输流程4.1 同一个局域网中的两台主机进…