庖丁解牛,MySQL执行计划Explain的2大核心

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 庖丁解牛,MySQL执行计划Explain的2大核心

🍁 一、Explain中的“Type”



c297594ff7ee46d1b4f273406b5b736c.png



Explain中的“Type”

MySQL的官网解释为:连接类型(the join type)。它描述了找到所需数据使用的扫描方式。


最为常见的扫描方式有:

system:系统表,少量数据,往往不需要进行磁盘IO;

const:常量连接;

eq_ref:主键索引(primary key)或者非空唯一索引(unique not null)等值扫描;

ref:非主键非唯一索引等值扫描;

range:范围扫描;

index:索引树扫描;

ALL:全表扫描(full table scan);

上面各类扫描方式由快到慢:

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


🍃1.1 system

扫码类型为system,说明数据已经加载到内存里,不需要进行磁盘IO。

这类扫描是速度最快的。

但是我没有遇到过,遇到了我再来补充!


🍃1.2 const

explain select id from account_user_base where id =1;

const扫描的条件为:

(1)命中主键(primary key)或者唯一(unique)索引;

(2)被连接的部分是一个常量(const)值;


🍃1.3 eq_ref

eq_ref扫描的条件为:对于前表的每一行(row),后表只有一行被扫描。

我也没有遇到!非常少见


🍃1.4 ref

explain select * from account_user_base t1,account_user_security t2 where t1.id = t2.user_id;

对于前表的每一行(row),后表可能有多于一行的数据被扫描。


🍃1.5 range

explain select * from account_user_base where id > 4;

range类型,它是索引上的范围查询,它会在索引上扫码特定范围内的值。


🍃1.6 index

explain select id from account_user_base;

index类型,需要扫描索引上的全部数据。


🍃1.7 ALL

explain select * from account_user_base;

全表扫描


🍃1.8总结


system最快:不进行磁盘IO

const:PK或者unique上的等值查询

eq_ref:PK或者unique上的join查询,等值匹配,对于前表的每一行(row),后表只有一行命中

ref:非唯一索引,等值匹配,可能有多行命中

range:索引上的范围扫描,例如:between/in/>

index:索引上的全集扫描

ALL最慢:全表扫描(full table scan)


🍁二、Explain中的“Extra”


bb54f7db821a40ca9afcbc4f6d9b2f75.png



Explain中的“Extra”

从上图我们得知,Extra的值有

NULL、Using index、Using where、Using index condition、Using filesort、Using temporary


🍃2.1 Using where

explain select * from account_user_base where id > 4;

Extra为Using where说明,SQL使用了where条件过滤数据。


🍃2.2 Using index

explain select id from account_user_base;

Extra为Using index说明,SQL所需要返回的所有列数据均在一棵索引树上,

而无需访问实际的行记录。


🍃2.3 Using index condition

explain select * from account_user_security t1, account_user_base t2 where t1.user_id = t2.id;

Extra为Using index condition说明,确实命中了索引,

但不是所有的列数据都在索引树上,还需要访问实际的行记录。


🍃2.4 Using filesort

explain select id from account_user_base order by nick_name;

Extra为Using filesort说明,得到所需结果集,需要对所有记录进行文件排序。

典型的,在一个没有建立索引的列上进行了order by,

就会触发filesort,常见的优化方案是,在order by的列上添加索引,避免每次查询都全量排序。


🍃2.5 Using temporary

explain select nick_name, COUNT(*) from account_user_base

GROUP BY nick_name order by nick_name;

Extra为Using temporary说明,需要建立临时表(temporary table)来暂存中间结果。

这类SQL语句性能较低,往往也需要进行优化。

典型的,group by和order by同时存在,且作用于不同的字段时,

就会建立临时表,以便计算出最终的结果集。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
27天前
|
SQL 关系型数据库 MySQL
深入解析MySQL的EXPLAIN:指标详解与索引优化
MySQL 中的 `EXPLAIN` 语句用于分析和优化 SQL 查询,帮助你了解查询优化器的执行计划。本文详细介绍了 `EXPLAIN` 输出的各项指标,如 `id`、`select_type`、`table`、`type`、`key` 等,并提供了如何利用这些指标优化索引结构和 SQL 语句的具体方法。通过实战案例,展示了如何通过创建合适索引和调整查询语句来提升查询性能。
131 9
|
2月前
|
缓存 关系型数据库 MySQL
MySQL执行计划选择策略:揭秘查询优化的艺术
【10月更文挑战第15天】 在数据库性能优化中,选择最优的执行计划是提升查询效率的关键。MySQL作为一个强大的关系型数据库管理系统,提供了复杂的查询优化器来生成执行计划。本文将深入探讨如何选择合适的执行计划,以及为什么某些计划更优。
143 2
|
2月前
|
缓存 关系型数据库 MySQL
MySQL执行计划深度解析:如何做出最优选择
【10月更文挑战第23天】 在数据库查询性能优化中,执行计划的选择至关重要。MySQL通过查询优化器来生成执行计划,但有时不同的执行计划会导致性能差异。理解如何选择合适的执行计划,以及为什么某些计划更优,对于数据库管理员和开发者来说是一项必备技能。
151 2
|
2月前
|
SQL 关系型数据库 MySQL
美团面试:Mysql如何选择最优 执行计划,为什么?
在40岁老架构师尼恩的读者交流群中,近期有小伙伴面试美团时遇到了关于MySQL执行计划的面试题:“MySQL如何选择最优执行计划,为什么?”由于缺乏系统化的准备,小伙伴未能给出满意的答案,面试失败。为此,尼恩为大家系统化地梳理了MySQL执行计划的相关知识,帮助大家提升技术水平,展示“技术肌肉”,让面试官“爱到不能自已”。相关内容已收录进《尼恩Java面试宝典PDF》V175版本,供大家参考学习。
|
3月前
|
SQL 关系型数据库 MySQL
MySQL EXPLAIN该如何分析?
本文将详细介绍MySQL中`EXPLAIN`关键字的工作原理及结果字段解析,帮助优化查询性能。`EXPLAIN`可显示查询SQL的执行计划,其结果包括`id`、`select_type`、`table`等字段。通过具体示例和优化建议,帮助你理解和应用`EXPLAIN`,提升数据库查询效率。
151 0
|
4月前
|
SQL 存储 关系型数据库
深入 MySQL 的执行计划与性能优化
深入 MySQL 的执行计划与性能优化
50 0
|
6月前
|
SQL 关系型数据库 MySQL
mysql性能调优:EXPLAIN命令21
【7月更文挑战第21天】掌握SQL性能调优:深入解析EXPLAIN命令的神奇用法!
67 1
|
6月前
|
SQL 缓存 关系型数据库
MySQL|浅谈explain的使用
【7月更文挑战第11天】
|
6月前
|
SQL 存储 数据库
MySQL设计规约问题之性能分析工具如Sql explain、show profile和mysqlsla在数据库性能优化中有什么作用
MySQL设计规约问题之性能分析工具如Sql explain、show profile和mysqlsla在数据库性能优化中有什么作用