MySQL EXPLAIN 完全解读

news2024/9/19 9:44:23

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.coloradmin.cn/o/2080315.html

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

相关文章

学习之数据库相关概念

数据库相关概念 主流的关系型数据库管理系统&#xff1a;

HIVE 数据仓库工具之第一部分(讲解部署)

HIVE 数据仓库工具 一、Hive 概述1.1 Hive 是什么1.2 Hive 产生的背景1.3 Hive 优缺点1.3.1 Hive的优点1.3.2 Hive 的缺点 1.4 Hive在Hadoop生态系统中的位置1.5 Hive 和 Hadoop的关心 二、Hive 原理及架构2.1 Hive 的设计原理2.2 Hive 特点2.3 Hive的体现结构2.4 Hive的运行机…

数据集的使用

一、 Transform与dataset数据集的使用 import torchvisionfrom torch.utils.tensorboard import SummaryWriterdataset_transform torchvision.transforms.Compose([torchvision.transforms.ToTensor()])train_set torchvision.datasets.CIFAR10(root "./dataset"…

《中文Python穿云箭量化平台二次开发技术03》利用Tkinter高级模块设计自己策略代码编辑器及策略运行窗口

《中文Python穿云箭量化平台》是纯Python开发的量化平台&#xff0c;因此其中很多Python模块&#xff0c;我们可以自己设计新的量化工具&#xff0c;例如自己新的行情软件、新的量化平台、以及各种量化研究工具。 穿云箭自带指标公式源码运行模块&#xff0c;可以为其他量化平台…

基于云原生的一体化监控系统Day1

7.1 监控体系部署管理 7.2k8s集群层面监控 准备&#xff1a;部署k8s集群 master&#xff1a;192.168.192.128 node01&#xff1a;192.168.192.129 node02&#xff1a;192.168.192.130 1.prometheus架构&#xff1a; prometheus工作原理&#xff1a; 1.数据采集&#xff…

AI视频平台精选:国内外对比与推荐

原文&#xff1a;AI视频平台精选&#xff1a;国内外对比与推荐 国内外有多个平台可以生成AI视频&#xff0c;这些平台各有其独特的优点和缺点。以下是对一些主要平台的详细介绍&#xff0c;包括它们的优缺点&#xff0c;以及针对个人和自媒体用户的推荐。 国内平台 1. 快手可…

为Windows Terminal 配置zsh + Oh-My-Zsh

参考&#xff1a; 为Windows Terminal 配置zsh Oh-My-Zsh 【核心】https://juejin.cn/post/7229507721795993661 https://blog.cloudorz.com/post/configure-zsh-for-windows-terminal/ https://zhuanlan.zhihu.com/p/455925403 本文以 Git Bash 终端为基础&#xff0c;来…

android openGL ES详解——剔除

一、正面剔除 在绘制3D场景的时候,我们需要决定哪些部分是对观察者 可见的,或者哪些部分是对观察者不可⻅的.对于不可见的部分,应该及早丢弃.例如在⼀个不透明的墙壁后,就不应该渲染.这种情况叫做”隐藏⾯消除”(Hidden surface elimination). 立方体中的正背面 任何物体都有…

Vue 项目中使用路由鉴权实现网页进度条

概述 在 Web 开发中&#xff0c;用户界面的流畅性和交互性对用户体验至关重要。为了在页面跳转时给用户提供反馈&#xff0c;我们可以利用 NProgress 这样的第三方库来实现一个进度条。本文档将指导您如何在 Vue 项目中结合路由鉴权来实现这一功能。 准备工作 确保您已经安装…

YOLO后处理trick - 减少nms的计算次数、比较次数和空间消耗

目录 前言 1.问题分析 问题1&#xff1a;排序问题 问题2&#xff1a;极大值抑制问题 2.优化比较和计算次数 优化1&#xff1a;跳过reshape直接置信度筛选 优化2&#xff1a;减少用于nms的bbox数 3.举个荔枝 总结 前言 减少YOLO后处理nms的计算和比较次数。 YOLO-det…

一 初识爬虫

一 爬虫和python 二 爬虫的合法性 三 爬虫的介绍 通过程序去访问网站&#xff0c;网站肯定希望用户来访问网站&#xff0c;而不是程序来访问&#xff0c;可以使用一些技术手段。设置障碍。 越过障碍。 四 爬虫示例 需求:用程序模拟浏览器。输入一个网址。从该网址中获取到资源或…

从短视频到AIGC,快手字节重开一局

作者 | 辰纹 来源 | 洞见新研社 从短视频到剪辑工具&#xff0c;从电商到外卖&#xff0c;再到如今的AIGC大模型&#xff0c;快手和字节的竞争从来就没有停止过。 通用大模型方面&#xff0c;快手有快意&#xff0c;字节有豆包&#xff1b;AI图片创作快手有可图&#xff0c;…

docker续3:

一、使用Dockerfile创建应用镜像 在Docker file中定义所需要执⾏的指令&#xff0c;使⽤ docker build创建镜像&#xff0c;过程中会按照dockerfile所定义的内容进⾏打开临时性容器&#xff0c;把docker file中命令全部执⾏完成&#xff0c;就得到了⼀个容器应⽤镜像&#xff…

星河社区升级命令行工具,一站式完成大模型实训

飞桨PFCC社区成员卢畅贡献。卢畅&#xff0c;飞桨 PFCC 成员&#xff0c;飞桨开源之星&#xff0c;飞桨开发者专家&#xff08;PPDE&#xff09;&#xff0c;长期参加飞桨黑客松、护航计划等开源活动&#xff0c;参与过飞桨执行器预分析性能优化、静态图自动并行架构升级等任务…

SpringBoot项目整合智谱AI + SSE推送流式数据到前端展示 + RxJava得浅显理解

项目背景&#xff1a; 项目背景是一个这个AI答题应用平台&#xff0c;我引入AI得作用就是让AI根据我指定得这个题目的标题和描述来生成一些列的题目。&#xff08;主要功能是这个&#xff0c;但是还用了AI给我评分&#xff0c;不过这个功能比较简单&#xff0c;在本文就简单介…

python可视化-条形图

1、加载数据 import pandas as pd import seaborn as sns import matplotlib.pyplot as plt# 导入数据 df pd.read_csv(E:/workspace/dataset/seaborn-data-master/tips.csv) df.head()2、基于seaborn的条形图 # 利用barplot函数快速绘制 sns.barplot(x"total_bill&quo…

Python从0到100(五十三):机器学习-决策树及决策树分类器

前言: 零基础学Python:Python从0到100最新最全教程。 想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Python爬虫、Web开发、 计算机视觉、机器学习、神经网络以及人工智能…

中微8S6990 EEPROM踩坑记录

中微8S6990 EEPROM内容丢失解决记录 问题描述: 问题程序如下: void temp_remember(uint16_t temperature,uint16_t address_H,uint16_t address_L) {uint8_t temp,temp1 0;temp temperature>>8;temp1 temperature;FLASH_UnLock();FLASH_Erase_DataArea(address_H);…

虹科方案 | 领航智能交通革新:虹科PEAK智行定位车控系统Demo版亮相

导读&#xff1a; 在智能汽车技术发展浪潮中&#xff0c;车辆控制系统的智能化、网络化已成为行业发展的必然趋势。虹科PEAK智行定位车控系统&#xff0c;集成了尖端科技&#xff0c;能够实现车辆全方位监控与控制的先进系统。从实时GPS定位到CAN/CANFD信号处理&#xff0c;虹科…

漏洞挖掘 | 记一次Spring横向渗透

0x1 前言 这篇文章给师傅们分享下&#xff0c;前段时间的一个渗透测试的一个项目&#xff0c;开始也是先通过各种的手段和手法利用一些工具啊包括空间引擎等站点对该目标公司进行一个渗透测试。前面找的突破口很少&#xff0c;不太好搞&#xff0c;但是后面找到了spring全家桶…