MySQL 的 Explain 命令

2024-05-24 11:12
文章标签 mysql 命令 explain database

本文主要是介绍MySQL 的 Explain 命令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用 MySQL 数据库时,经常会有查询效率慢的时候,此时就需要进行优化,Explain 就是用来帮助开发者完成优化分析的重要命令,他能直观的显示出来此时 SQL 语句执行的情况,比如常见的是否使用了索引,用了哪个索引,以及访问了多少条数据才得到结果的数据等。

这也是面试当中常见的考点。

字段含义

首先我们先执行一条查询语句,查询语句前加上 Explain 用来显示执行情况。

EXPLAIN SELECT * FROM user;

控制台可以得到执行情况的表格。

 id

SELECT 查询的标识符,标识查询的顺序,id越大执行的优先级越高。

select_type

查询的类型,主要用来区分普通查询、联合查询、子查询等复杂的查询。常见的有:

  • SIMPLE:简单查询
  • PRIMARY:查询中如果包含子查询或其他部分,外层的 SELECT 将被标为 PRIMARY
  • SUBQUERY:子查询的第一个 SELECT
  • UNION:在 UNION 语句中, UNION 之后出现的 SELECT
  • DERIVED:在 FROM 中出现的子查询将被标记为 DERIVED
  • UNION RESULT:UNION 查询的结果

table

就是表的意思,查询的哪个表

partitions

表示查询涉及到的分区。如果有使用分区表的话才会有值需要考虑。

type

分析 SQL 优化最主要的字段,标识查询执行的类型,描述是怎样执行的查询。性能从高到低:

system > const > qe_ref > ref > fulltext > ref_of_null > index_merge > unique_subquery > index_subquery > range > index > ALL

比较常见的有:

system:表示查询的只有一行

const:表中最多只有一行匹配的记录,一次查询就可以查询到,使用唯一索引或者主键索引时常见

EXPLAIN SELECT * FROM user where id = 1;

eq_ref:当连表查询时,前一张表中只有一行与之对应。是出了 system 和 const 之外最好的 join方式,常用于使用主键或者唯一索引的所有字段作为连表条件。

EXPLAIN SELECT * FROM employees e JOIN departments d ON e.department_id = d.department_id;

ref:使用普通索引作为查询条件,查询结果可能找到多个符合条件的行。

EXPLAIN SELECT * FROM employees WHERE department_id = 5;

index_merge:当查询条件使用了多个索引时,表示开启了 index merge 优化,此时执行计划中的 key 列出了使用的索引。

range:对索引列进行范围查询,执行计划中的 eky 表示哪个索引被使用了。常出现在使用索引的范围查询中。

EXPLAIN SELECT * FROM employees WHERE salary BETWEEN 50000 AND 100000;

index:查询遍历了整个索引树,和 all 相似,不过扫面的是索引,索引是保存在内存中的,速度更快。

EXPLAIN SELECT name FROM employees;

ALL:全表扫描,性能最差的。

possible_keys

表示MySQL执行查询时可能用到的索引,如果这一列时 null,表示没有可能用到的索引,此时如果想要使用索引做优化,可以选择查询条件中的字段添加索引,可以是一个也可以是多个,来提高性能。

key

key 表示实际使用到的索引,如果为 null 表示没有使用到索引,如果字段是有索引的,需要检查所有失效的原因。

key_len

表示MySQL 实际使用的索引最大长度,当使用到联合索引时,有可能时多个列的长度和,在满足需求的前提下,越短越好,如果 key 显示的 null,那么 key_len 也为 null

rows

表示根据表统计信息和选用情况,大致估算出找到所需记录的行数,越小越好。

filtered

显示查询条件过滤掉的行的百分比。百分比越高,表示查询条件的选择性越好。

Extra

执行的 sql 额外信息,通过额外信息可以准确直到 MySQL是怎样执行查询的。

常见:

using filesort:排序时使用了外部的索引,没有使用表内的索引排序

using temporary:创建临时表来存储查询结果,比如在使用 group by 和 order by 的时候

using index:使用了覆盖索引,即查询条件中的查询字段就是想要查询的字段,不用回表查询,比如使用了查询主键,使用了主键索引,直接查到的就是主键

using index condition:表示使用了索引下推

using where:查询使用的 where 条件,一般出现在没有使用到索引时

using join buffer:连表查询的方式,表示被驱动表的没有使用索引的时候,MySQL 会先将驱动表读出来放到 buffer中,再遍历被驱动表和驱动表进行查询。

需要注意,using filesort 和 using temporary,可能出现性能问题,需要避免。

来源:MySQL执行计划分析 | JavaGuide

这篇关于MySQL 的 Explain 命令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/998247

相关文章

SQL Server 中的表进行行转列场景示例

《SQLServer中的表进行行转列场景示例》本文详细介绍了SQLServer行转列(Pivot)的三种常用写法,包括固定列名、条件聚合和动态列名,文章还提供了实际示例、动态列数处理、性能优化建议... 目录一、常见场景示例二、写法 1:PIVOT(固定列名)三、写法 2:条件聚合(CASE WHEN)四、

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb

MySQL 筛选条件放 ON后 vs 放 WHERE 后的区别解析

《MySQL筛选条件放ON后vs放WHERE后的区别解析》文章解释了在MySQL中,将筛选条件放在ON和WHERE中的区别,文章通过几个场景说明了ON和WHERE的区别,并总结了ON用于关... 今天我们来讲讲数据库筛选条件放 ON 后和放 WHERE 后的区别。ON 决定如何 "连接" 表,WHERE

mysql_mcp_server部署及应用实践案例

《mysql_mcp_server部署及应用实践案例》文章介绍了在CentOS7.5环境下部署MySQL_mcp_server的步骤,包括服务安装、配置和启动,还提供了一个基于Dify工作流的应用案例... 目录mysql_mcp_server部署及应用案例1. 服务安装1.1. 下载源码1.2. 创建独立

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

MySQL日志UndoLog的作用

《MySQL日志UndoLog的作用》UndoLog是InnoDB用于事务回滚和MVCC的重要机制,本文主要介绍了MySQL日志UndoLog的作用,文中介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、Undo Log 的作用二、Undo Log 的分类三、Undo Log 的存储四、Undo

MySQL游标和触发器的操作流程

《MySQL游标和触发器的操作流程》本文介绍了MySQL中的游标和触发器的使用方法,游标可以对查询结果集进行逐行处理,而触发器则可以在数据表发生更改时自动执行预定义的操作,感兴趣的朋友跟随小编一起看看... 目录游标游标的操作流程1. 定义游标2.打开游标3.利用游标检索数据4.关闭游标例题触发器触发器的基

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

MySQL底层文件的查看和修改方法

《MySQL底层文件的查看和修改方法》MySQL底层文件分为文本类(可安全查看/修改)和二进制类(禁止手动操作),以下按「查看方法、修改方法、风险管控三部分详细说明,所有操作均以Linux环境为例,需... 目录引言一、mysql 底层文件的查看方法1. 先定位核心文件路径(基础前提)2. 文本类文件(可直

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两