MySql中explain的用法

article/2025/9/29 14:49:48

explain命令展示MySQL如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。

explain命令使用

只需要在select前面加上EXPLAIN即可,如:

explain select * from table_name where col_name = XX

注:explain只对select查询做解释,insert、update、delete不会

explain列的解释

在这里插入图片描述
id:select标识符,即selct查询序列号

select_type:

列名释义
select类型
simple简单的select,没有union和子查询
primary最外层的select,在有子查询的语句中,最外面的select查询就是primary
derived派生表的查询语句,即当一个表不是一个物理表
union union语句的第二个

table:输出的行所用的表

type:表使用的连接方式

列名释义
const当这个表只有一个row时会出现
eq_ref在查询时从前面的表中,对每一个记录的联合都从表中读取一个记录,它在查询使用了索引为主键或惟一键的全部时使用
ref查询使用了不是唯一或主键的键或者这些类型的部分时发生
range返回一个范围中的行
index对前面的表中的每一个记录进行完全扫描
all对于前面的每一个记录联合进行完全扫描,应该尽量避免

possible_keys:显示可能应用在这张表中的索引

key:显示采用哪个索引来优化对该表的访问

key_len :使用的索引长度

ref:显示索引的哪一列被使用了,如果可能的话,是一个常数

rows:mysql认为必须检查的用来返回请求数据的行数

extra:关于mysql如何解析查询的额外信息

列名释义
distinct一旦mysql找到了与行相联合匹配的行,就不再搜索了
not existmysql 优化了left join,一旦找到了匹配left join标准的行,就不再搜索
using filesortmysql需要进行额外的步骤来发现如何对返回的行进行排序
using temporarymysql需要创建一个临时表来存储结果,这通常发生在对不同的列集进行order by上,而不是group by上


http://chatgpt.dhexx.cn/article/u8TMKpod.shtml

相关文章

MySQL中的Explain用法

一、Explain介绍   使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而就可以知道MySQL是如何处理你的SQL语句的,可以用来分析你的查询语句或者是表结构的性能瓶颈。   通过EXPLAIN我们可以分析出以下结果:     ●表的读取顺序  …

mysql中explain用法和结果的含义

explain select * from user explain extended select * from user id SELECT识别符。这是SELECT的查询序列号 select_type SELECT类型,可以为以下任何一种: SIMPLE:简单SELECT(不使用UNION或子查询) PRIMARY:最外面的SELECT UNION:UNION中的第二个或后面的SELECT语句 DEPEND…

EXPLAIN用法解析

1. EXPLAIN简介 使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或是表结构的性能瓶颈。 ➤ 通过EXPLAIN,我们可以分析出以下结果: 表的读取顺序 数据读取操作的操作类型 哪些索引…

MySQL中Explain用法详解

Explain简介 我们在写后端程序的时候,通常会写sql来查询数据,如果是单表查询的时候,那直接select就完事了,但是如果是连表查询数据量也不小的话,就造成了查询速度会比较慢,那么我们该怎么知道我的sql的实际…

【MySQL】explain 用法详解

【MySQL】explain 用法详解 explain命令主要来查看SQL语句的执行计划,查看该SQL语句有没有使用索引,有没有做全表扫描等。它可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理用户的SQL语句。 文章目录 【MySQL】explain 用法详解一、e…

Explain详解

目录 一、表信息 二、explain 的两种使用方式 三、explain中的列 1. id列 2. select_type列 3. table列 4. type列 5. possible_keys列 6. key列 7. key_len列 8. ref列 9. rows列 10. Extra列 四、索引最佳实践 使用EXPLAIN关键字可以模拟优化器执行SQL语句&…

mysql 用法 Explain

前言:explain(执行计划),使用explain关键字可以模拟优化器执行sql查询语句,从而知道MySQL是如何处理sql语句。explain主要用于分析查询语句或表结构的性能瓶颈。 注:本系列随笔如无特殊说明都MySQL版本都为…

Mysql中explain的用法详解

🍓 简介:java系列技术分享(👉持续更新中…🔥) 🍓 初衷:一起学习、一起进步、坚持不懈 🍓 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正🙏 🍓 希望这篇文章对你有所帮助,欢…

explain用法和结果分析

1. EXPLAIN简介 使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或是表结构的性能瓶颈。 通过explain我们可以获得以下信息: 表的读取顺序数据读取操作的操作类型哪些索引可以使用哪些索引被实…

Explain使用详解

在日常开发工作中,对于SQL的书写,通常都会尽量让SQL能够使用到表中创建的索引,以此来提高SQL语句的性能。想要参看一个SQL是否会使用索引,可以使用MySQL字段的分析工具Explain,这篇文章重要介绍该工具的使用。 一、 简…

EXPLAIN 的用法

用法简介 EXPLAIN 的用法很简单,只需要在你的 SQL 前面加上 EXPLAIN 即可。例如: explain select * from t; PS:insert、update、delete 同样可以通过 explain 查看执行计划,不过通常我们更关心 select 的执行情况 你会看到如下…

[MySQL高级](一) EXPLAIN用法和结果分析

1. EXPLAIN简介 使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或是表结构的性能瓶颈。 ➤ 通过EXPLAIN,我们可以分析出以下结果: 表的读取顺序数据读取操作的操作类型哪些索引可…

.NET6.0的日志组件Log4net

前言:不允许让没有任何日志监控的项目上线,所以说真正开发起来必须要有监控,相当于多一双眼睛帮着我们看项目在运行时会不会有什么问题,我们要不断的在每个环节写日志,这样发生异常我们可以快速知道哪里有问题了&#…

Unity接入日志插件Log4Net

前言 log4net是一个日志插件,可以帮助我们把控制台输出的日志写入到本地。这个功能说简单就简单,说复杂其实还挺复杂。 为什么这么说呢,首先文件写入本地确实简单,但是如果你要实现一下功能就没那么简单了。 1.把每行日志按照指…

log4net多进程丢失日志的解决方法

首先为什么会有多进程同时记录日志到同一个文件夹同一个文件里呢,每个项目肯定有每个项目的特殊性,我这里.net的BS项目,主要是因为在IIS里,应用程序池,最大工作进程设置成2,就会出现2个w3p什么的进程同时运…

C# log4net 日志输出超详细

思路: 1.安装插件:安装log4net 2.使用配置:添加log4net配置信息 3.输出日志文件格式:添加日志配置 4.AssemblyInfo.cs中配置 第一步:安装log4net 第二步:在app.config添加log4net配置 新增log4net.config…

.Net Core3.1 集成Log4net

准备 第一步:nuget 引用 Microsoft.Extensions.Logging.Log4Net.AspNetCore 第二步:在项目中添加log4net.config的配置文件(配置文件在文末) 第三步:在项目中注册使用log4net 方法一:在Program.cs中注册,找到 Prog…

C#上位机开发(十三)—— 使用Log4net添加日志记录功能

一、Log4net 官方网站:https://logging.apache.org/log4net/。 下载二进制dll库: 包中提供了针对各个版本的dll库: 二、使用日志库 1. 添加库 复制对应的库文件到项目中: 2. 配置log4net 2.1. 创建配置文件 添加后修改该文件设置:

unity log4net

log4.et.confog.xml <?xml version"1.0" encoding"utf-8" ?><log4net> <appender name"Error" type"log4net.Appender.RollingFileAppender"> <lockingModel type"log4net.Appender.FileAppenderMinimal…

C#-Winform之log4net使用详细记录

一、作用 提供一个记录日志的框架&#xff0c;可以将日志信息记录到文件、控制台、Windows事件日志和数据库&#xff08;MSSQL、Acess、Oracle、DB2和SQLite等&#xff09;。 二、操作步骤 1.在项目中添加对log4net.dll的引用&#xff08;通过NuGet可以直接安装&#xff09; …