mysql的explain

explain可以用于select,delete,insert,update的statement。
当explain用于statement时,mysql将会给出其优化器(optimizer)的执行计划。
在这里插入图片描述
通过explain字段生成执行计划表。下面来解析这个执行计划表的每一列的意义。

执行计划表的每一行都描述了查询执行计划中的一个操作或阶段。

id:表示执行顺序,越大越先,相同按展示顺序

select_type(查询的类型)

  • SIMPLE: 一个简单的 SELECT 查询,不包含子查询或 UNION。通常情况下,优化器能够直接确定最佳的执行计划。

  • PRIMARY: 主查询,复杂查询的最外层。

  • SUBQUERY: 不包含在form中的子查询

  • DERIVED: 包含在form中的子查询,mysql会将查询结果放到一个临时表中

  • UNION: 这表示 UNION 查询的第二个或后续查询语句。

table:操作的表

(不重要)partitions:表示查询涉及的分区信息。分区是将表拆分成独立的片段,每个片段称为一个分区,可以根据特定的规则将数据分布到不同的分区中

type:连接方法或者查找中的访问方法

从优到最差的排列:system>const>eq_ref>ref>range>index>ALL

  • null:什么都不做

  • const: 假如user_id 是主键,你使用 WHERE user_id = 1,主键和常量。

  • eq_ref: 访问类型表示在查询中使用了等值连接,并且连接的列在右侧表中是唯一索引,查找聚簇索引树返回数据行。

SELECT *
FROM orders
JOIN customers ON orders.customer_id = customers.customer_id;
  • ref: 基于非唯一索引进行查找,可能返回多个匹配值,因此需要通过引用来进行访问。查找聚簇索引树返回数据行。

  • range: 使用索引进行范围扫描,返回一个范围内的行。

  • index: 查找二级索引树返回聚簇索引值。

  • ALL: 全表扫描,检索表中的所有行,这是最慢的访问方式之一。

possible_key(没啥用):就是可能使用的index,但是没使用

key:查询使用的索引

key_len:表示了索引键的前缀长度,或者是索引键的完整长度

ref:

rows:这个值表示了在执行查询时,MySQL 预计需要扫描和检查的行数,而不是实际返回的行数。

filtered:

Extra:

覆盖索引的意思就是查询结果可以完全由索引列提供,而不需要额外的表访问。
eg.SELECT username FROM users; //username有索引,索引列就是结果

  • Using index: 表示 MySQL 使用了覆盖索引,即只使用了索引而没有访问表中的实际行数据。

  • Using where: 表示 MySQL 在查询中使用了 WHERE 子句中的条件进行筛选,而不是在 Using index 标记中的索引中完成筛选。

  • Using temporary: 表示 MySQL 在执行查询时创建了临时表。

创建使用临时表的情况:sort by,group by,join,子查询

  • Using filesort: 表示 MySQL 在执行查询时使用了文件排序操作。

filesort:将查询结果写入临时文件中,并对临时文件中的数据进行排序操作。

  • Using join buffer: 表示 MySQL 在执行联接操作时使用了联接缓冲区,通常发生在需要对大量数据进行联接时,可以提高查询性能。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

正则表达式和sed

一、正则表达式 主要用来匹配字符串(命令结果,文本内容), 通配符匹配文件(而且是已存在的文件) 基本正则表达式 扩展正则表达式 1.元字符 . 匹配任意单个字符,可以是一个汉字 […

【企业宣传片】拍摄思维提升,专业影视质感核心揭密,一课搞定

课程下载:【企业宣传片】拍摄-课程网盘链接提取码下载.txt资源-CSDN文库 更多资源下载:关注我。 课程介绍 大量案例分析宣传片拍摄的痛点要点 根据案例告诉你解决方案,讲透概念 改变你对企业宣传片的思维层级与认知 归纳总结对比不同案…

基于SSM的婚恋网站的设计与实现(有报告)。Javaee项目。ssm项目。

演示视频: 基于SSM的婚恋网站的设计与实现(有报告)。Javaee项目。ssm项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构,通过Spri…

MS41908M替代AN41908

产品简述 MS41908M 是一款用于网络摄像机和监控摄像机的镜头 驱动芯片他可完全替代AN41908。 芯片内置光圈控制功能;通过电压驱动方式以及扭矩纹 波修正技术,实现了噪声微步驱动。 主要特点 电压驱动方式,256 微步驱动电路(两通道…

多区域OSPF路由配置

一、基础配置 1.搭建实验拓扑图 2.实验编址 具体如何配置可以看这一篇详细的博文:单区域OSPF实验-CSDN博客 3.分别检查六个路由器的配置: 使用命令display ip interface brief R1的配置 其他大家可以调出来,再与实验拓扑图进行比对&#…

机器人非线性系统反馈线性化与解耦

机器人非线性系统的反馈线性化和解耦是控制理论中的两个重要概念,它们分别用于简化系统分析和设计过程,提高控制系统的性能。 首先,反馈线性化是一种将非线性系统转化为线性系统的技术。在机器人控制中,由于机器人本身是一个强耦…

那些年我与c++的叫板(一)--string类自实现

引子:我们学习了c中的string类,那我们能不能像以前数据结构一样自己实现string类呢?以下是cplusplus下的string类,我们参考参考! 废话不多说,直接代码实现:(注意函数之间的复用&…

【C语言】5.C语言函数(2)

文章目录 7.嵌套调⽤和链式访问7.1 嵌套调⽤7.2 链式访问 8.函数的声明和定义8.1 单个⽂件8.2 多个⽂件8.3 static 和 extern8.3.1 static 修饰局部变量8.3.2 static 修饰全局变量8.3.3 static 修饰函数 7.嵌套调⽤和链式访问 7.1 嵌套调⽤ 嵌套调用就是函数之间的互相调用。…

1、sql server数据库进行sql注入

靶机取自:墨者sql server 1、判断数据库类型 抓包知sql server,所以注入语句跟MySQL有些区别 2、判断注入点 “http://219.153.49.228:42514/new_list.asp?id2 ”,当id2 and 11时显示正确,id2 and 12时页面报错。 3、确定列…

BERT for Joint Intent Classification and Slot Filling 论文阅读

BERT for Joint Intent Classification and Slot Filling 论文阅读 Abstract1 Introduction2 Related work3 Proposed Approach3.1 BERT3.2 Joint Intent Classification and Slot Filling3.3 Conditional Random Field 4 Experiments and Analysis4.1 Data4.2 Training Detail…

【董晓算法】动态规划之背包DP问题(2024.5.11)

前言: 本系列是学习了董晓老师所讲的知识点做的笔记 董晓算法的个人空间-董晓算法个人主页-哔哩哔哩视频 (bilibili.com) 动态规划系列 【董晓算法】动态规划之线性DP问题-CSDN博客 01背包 步骤: 分析容量j与w[i]的关系,然后分析是否…

FreeRTOS消息队列queue.c文件详解

消息队列的作用 消息队列主要用来传递消息,可以在任务与任务之间、中断与任务之间传递消息。 传递消息是通过复制的形式,发送方发送时需要不断复制,接收方接收时也需要不断复制。虽然会有内存资源的浪费,但是可以保证安全。 假…

为什么descriptor和data分离可以内存高效率

以下为例,需要有前面的6个bytes开始,用来处理数据,一旦这6个bytes有了即可以处理了。 Descriptor和data是同样的,只有descriptor有了,即可以开始处理data了。所以data不需要停留更长时间。

函数递归练习

目录 1.分析下面选择题 2.实现求第n个斐波那契数 3.编写一个函数实现n的k次方,使用递归实现。 4.写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和 5.递归方式实现打印一个整数的每一位 6.实现求n的阶乘 1.分析下面选择…

vs2022中添加头文件和声明

总结帖 数组存储 matlab中3维数组–>C中1维数组 数组转置函数 #include <stdio.h>// 转置二维数组 void transpose(int *src, int *dest, int rows, int cols) {for (int i 0; i < rows; i) {for (int j 0; j < cols; j) {dest[j * rows i] src[i * col…

解析C++ 网络输入输出缓冲区Buffer类的设计与实现(muduo库)

网络输入输出缓冲区&#xff08;Buffer&#xff09;是为了优化网络通信性能而设计的。通过将数据存储在缓冲区中&#xff0c;可以减少对网络的频繁访问&#xff0c;提高数据传输效率。缓冲区还可以帮助处理数据流中的突发性和短时延&#xff0c;使得数据的发送和接收更加稳定和…

最新版Ceph( Reef版本)块存储简单对接k8s(上集)

当前ceph 你的ceph集群上执行 1.创建名为k8s-rbd 的存储池 ceph osd pool create k8s-rbd 64 642.初始化 rbd pool init k8s-rbd3 创建k8s访问块设备的认证用户 ceph auth get-or-create client.kubernetes mon profile rbd osd profile rbd poolk8s-rbd部署 ceph-rbd-csi c…

C++map容器关联式容器

Cmap 1. 关联式容器 vector、list、deque、forward_list(C11)等STL容器&#xff0c;其底层为线性序列的数据结构&#xff0c;里面存储的是元素本身&#xff0c;这样的容器被统称为序列式容器。而map、set是一种关联式容器&#xff0c;关联式容器也是用来存储数据的&#xff0…

专“蜀”盛会!CGT Asia 2024 第六届亚洲细胞与基因治疗创新峰会(成都站)7月火热相邀

在细胞与基因治疗领域&#xff0c;我们正站在一个科技革命的风口上。中国的CGT市场预计将持续快速增长。根据相关分析&#xff0c;预计到2025年整体市场规模将达到25.9亿美元&#xff0c;显示出276%的复合年增长率。这一增长趋势预计将持续到2030年&#xff0c;细胞与基因治疗领…

【利用数组处理批量数据-谭浩强配套】(适合专升本、考研)

无偿分享学习资料&#xff0c;需要的小伙伴评论区或私信dd。。。 无偿分享学习资料&#xff0c;需要的小伙伴评论区或私信dd。。。 无偿分享学习资料&#xff0c;需要的小伙伴评论区或私信dd。。。 完整资料如下&#xff1a;纯干货、纯干货、纯干货&#xff01;&#xff01;…