我的编程空间,编程开发者的网络收藏夹
学习永远不晚

使用MySQL的Explain执行计划的方法(SQL性能调优)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

使用MySQL的Explain执行计划的方法(SQL性能调优)

前言

上篇文章讲了MySQL架构体系,了解到MySQL Server端的优化器可以生成Explain执行计划,而执行计划可以帮助我们分析SQL语句性能瓶颈,优化SQL查询逻辑,今天就一块学习Explain执行计划的具体用法。

1. explain的使用

使用EXPLAIN关键字可以模拟优化器执行SQL语句,分析你的查询语句或是结构的性能瓶颈。 在 select 语句之前增加 explain 关键字,MySQL 会在查询上设置一个标记,执行查询会返回执行计划的信息,并不会执行这条SQL。

就比如下面这个:

输出这么多列都是干嘛用的?

其实大都是SQL语句的性能统计指标,先简单总结一下每一列的大致作用,下面详细讲一下:

2. explain字段详解

下面就详细讲一下每一列的具体作用。

id列

id表示查询语句的序号,自动分配,顺序递增,值越大,执行优先级越高。

id相同时,优先级由上而下:

select_type列

select_type表示查询类型,常见的有SIMPLE简单查询、PRIMARY主查询、SUBQUERY子查询、UNION联合查询、UNION RESULT联合临时表结果等。

table列

table表示SQL语句查询的表名、表别名、临时表名。

partitions列

partitions表示SQL查询匹配到的分区,没有分区的话显示NULL。

type列

type表示表连接类型或者数据访问类型,就是表之间通过什么方式建立连接的,或者通过什么方式访问到数据的。

具体有以下值,性能由好到差依次是:

system > const > eq_ref > ref > ref_or_null > index_merge > range > index > ALL

system

当表中只有一行记录,也就是系统表,是 const 类型的特列。

const

表示使用主键或者唯一性索引进行等值查询,最多返回一条记录。性能较好,推荐使用。

eq_ref

表示表连接使用到了主键或者唯一性索引,下面的SQL就用到了user表主键id。

ref

表示使用非唯一性索引进行等值查询。

ref_or_null

表示使用非唯一性索引进行等值查询,并且包含了null值的行。

index_merge

表示用到索引合并的优化逻辑,即用到的多个索引。

range

表示用到了索引范围查询。

index

表示使用索引进行全表扫描。

ALL

表示全表扫描,性能最差。

possible_keys列

表示可能用到的索引列,实际查询并不一定能用到。

key列

表示实际查询用到索引列。

key_len列

表示索引所占的字节数。

每种类型所占的字节数如下:

类型占用空间
char(n)n个字节
varchar(n)2个字节存储变长字符串,如果是utf-8,则长度 3n + 2
tinyint1个字节
smallint2个字节
int4个字节
bigint8个字节
date3个字节
timestamp4个字节
datetime8个字节
字段允许为NULL额外增加1个字节

ref列

表示where语句或者表连接中与索引比较的参数,常见的有const(常量)、func(函数)、字段名。

如果没用到索引,则显示为NULL:

rows列

表示执行SQL语句所扫描的行数。

filtered列

表示按条件过滤的表行的百分比。

用来估算与其他表连接时扫描的行数,row x filtered = 252004 x 10% = 25万行

Extra列

表示一些额外的扩展信息,不适合在其他列展示,却又十分重要。

Using where

表示使用了where条件搜索,但没有使用索引。

Using index

表示用到了覆盖索引,即在索引上就查到了所需数据,无需二次回表查询,性能较好。

Using filesort

表示使用了外部排序,即排序字段没有用到索引。

Using temporary

表示用到了临时表,下面的示例中就是用到临时表来存储查询结果。

Using join buffer

表示在进行表关联的时候,没有用到索引,使用了连接缓存区存储临时结果。

下面的示例中user_id在两张表中都没有建索引。

Using index condition

表示用到索引下推的优化特性。

知识点总结

本文详细介绍了Explain使用方式,以及每种参数所代表的含义。无论是工作还是面试,使用Explain优化SQL查询,都是必备的技能,一定要牢记。

SQL查询优化方式图表:

到此这篇关于使用MySQL的Explain执行计划的方法(SQL性能调优)的文章就介绍到这了,更多相关MySQL Explain内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

使用MySQL的Explain执行计划的方法(SQL性能调优)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

使用MySQL的Explain执行计划的方法(SQL性能调优)

这篇文章主要介绍了使用MySQL的Explain执行计划的方法(SQL性能调优),使用EXPLAIN关键字可以模拟优化器执行SQL语句,具体详解,需要的小伙伴可以参考一下
2022-11-13

Oracle执行计划及性能调优详解使用方法

目录1. EXPLAIN PLAN 简介2. EXPLAIN PLAN 输出解释3. 关键性能指标1. Cost(成本)2. Cardinality(基数)3. Rows(返回行数)4. Time(执行时间)5. Operation(操作类
Oracle执行计划及性能调优详解使用方法
2024-09-24

MySQL SQL性能分析之慢查询日志、explain使用的方法是什么

本篇内容介绍了“MySQL SQL性能分析之慢查询日志、explain使用的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!SQL执
2023-04-19

优化数据库性能:MySQL主从复制在集群技术中的最佳使用方法

优化数据库性能:MySQL主从复制在集群技术中的最佳使用方法摘要:随着互联网的快速发展,数据库的性能问题成为了各个企业和组织关注的焦点。MySQL主从复制技术在解决数据库性能瓶颈方面发挥着重要作用。本文将介绍MySQL主从复制的概念及原理,
2023-10-22

编程热搜

目录