返回顶部
首页 > 资讯 > 数据库 >Mysql explain用法与结果深入分析
  • 683
分享到

Mysql explain用法与结果深入分析

explainmysqlmysql索引explainexplain的使用 2022-05-26 00:05:22 683人浏览 安东尼
摘要

前言 在日常工作中,我们会有时会开慢查询去记录一些执行时间比较久的sql语句,找出这些SQL语句并不意味着完事了,些时我们常常用到explain这个命令来查看一个这些SQL语句的执行计划,查看该SQL语句有没有使用上

前言

在日常工作中,我们会有时会开慢查询去记录一些执行时间比较久的sql语句,找出这些SQL语句并不意味着完事了,些时我们常常用到explain这个命令来查看一个这些SQL语句的执行计划,查看该SQL语句有没有使用上了索引,有没有做全表扫描,这都可以通过explain命令来查看。所以我们深入了解Mysql的基于开销的优化器,还可以获得很多可能被优化器考虑到的访问策略的细节,以及当运行SQL语句时哪种策略预计会被优化器采用。(QEP:sql生成一个执行计划query Execution plan)


mysql> explain select * from servers;
+----+-------------+---------+------+---------------+------+---------+------+------+-------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+---------+------+---------------+------+---------+------+------+-------+
| 1 | SIMPLE  | servers | ALL | NULL   | NULL | NULL | NULL | 1 | NULL |
+----+-------------+---------+------+---------------+------+---------+------+------+-------+
1 row in set (0.03 sec)

1. EXPLAIN简介

使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或是表结构的性能瓶颈。 通过explain我们可以获得以下信息:

  • 表的读取顺序
  • 数据读取操作的操作类型
  • 哪些索引可以使用
  • 哪些索引被实际使用
  • 表之间的引用
  • 每张表有多少行被优化器查询

使用方法:explain + sql语句。 包含的字段如下

2. 执行计划各字段含义

2.1 id

id相同,执行顺序由上至下

id不同,如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行

id相同不同,同时存在  id相同的可以认为是一组,同一组中从上往下执行,所有组中id大的优先执行

2.4 type

type所显示的是查询使用了哪种类型,type包含的类型包括如下图所示的几种,从好到差依次是

system > const > eq_ref > ref > range > index > all

  • system 表只有一行记录(等于系统表),这是const类型的特列,平时不会出现,这个也可以忽略不计
  • const 表示通过索引一次就找到了,const用于比较primary key 或者unique索引。因为只匹配一行数据,所以很快。如将主键置于where列表中,MySQL就能将该查询转换为一个常量。
  • eq_ref 唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。常见于主键或唯一索引扫描
  • ref 非唯一性索引扫描,返回匹配某个单独值的所有行,本质上也是一种索引访问,它返回所有匹配某个单独值的行,然而,它可能会找到多个符合条件的行,所以他应该属于查找和扫描的混合体。
  • range 只检索给定范围的行,使用一个索引来选择行,key列显示使用了哪个索引,一般就是在你的where语句中出现between、< 、>、in等的查询,这种范围扫描索引比全表扫描要好,因为它只需要开始于索引的某一点,而结束于另一点,不用扫描全部索引。
  • index   Full Index Scan,Index与All区别为index类型只遍历索引树。这通常比ALL快,因为索引文件通常比数据文件小。(也就是说虽然all和Index都是读全表,但index是从索引中读取的,而all是从硬盘读取的)
  • all   Full Table Scan 将遍历全表以找到匹配的行

2.5 possible_keys 和 key

possible_keys 显示可能应用在这张表中的索引,一个或多个。查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询实际使用。

key实际使用的索引,如果为NULL,则没有使用索引。(可能原因包括没有建立索引或索引失效)

2.6 key_len

表示索引中使用的字节数,可通过该列计算查询中使用的索引的长度,在不损失精确性的情况下,长度越短越好。

2.7 rows

根据表统计信息及索引选用情况,大致估算出找到所需的记录所需要读取的行数,也就是说,用的越少越好

2.8 Extra

2.8.1 Using filesort

说明mysql会对数据使用一个外部的索引排序,而不是按照表内的索引顺序进行读取。MySQL中无法利用索引完成的排序操作称为“文件排序”。

2.8.2 Using temporary

使用了用临时表保存中间结果,MySQL在对查询结果排序时使用临时表。常见于排序order by和分组查询group by。

2.8.3 Using index

表示相应的select操作中使用了覆盖索引(Covering Index),避免访问了表的数据行,效率不错。如果同时出现using where,表明索引被用来执行索引键值的查找;如果没有同时出现using where,表明索引用来读取数据而非执行查找动作。

2.8.4 Using join buffer

表明使用了连接缓存,比如说在查询的时候,多表join的次数非常多,那么将配置文件中的缓冲区的join buffer调大一些。

总结

到此这篇关于Mysql explain用法与结果深入分析的文章就介绍到这了,更多相关Mysql explain用法与结果内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

您可能感兴趣的文档:

--结束END--

本文标题: Mysql explain用法与结果深入分析

本文链接: https://lsjlt.com/news/10105.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Mysql explain用法与结果深入分析
    前言 在日常工作中,我们会有时会开慢查询去记录一些执行时间比较久的SQL语句,找出这些SQL语句并不意味着完事了,些时我们常常用到explain这个命令来查看一个这些SQL语句的执行计划,查看该SQL语句有没有使用上...
    99+
    2022-05-26
    explain mysql mysql索引explain explain的使用
  • 分析MySQL EXPLAIN结果集
    这篇文章主要介绍“分析MySQL EXPLAIN结果集”,在日常操作中,相信很多人在分析MySQL EXPLAIN结果集问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析My...
    99+
    2024-04-02
  • MySQL用法中对explain的用法和结果分析
    本篇文章和大家了解一下MySQL用法中对explain的用法和结果分析。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。1. EXPLAIN简介使用EXPLAIN关键字可以模拟优化器执行SQ...
    99+
    2024-04-02
  • 深入浅析MySQL Explain
    目录一、id二、select_type三、table四、type五、possible_keys六、Key七、key_len八、ref九、rows十、Extra在日常工作中,我们会有时会开慢查询去记录一些执行时间...
    99+
    2022-07-08
    MySQL Explain MySQL Explain详解
  • 深入浅析MySQL Explain
    目录一、id二、select_type三、table四、type五、possible_keys六、Key七、key_len八、ref九、rows十、Extra在日常工作中,...
    99+
    2024-04-02
  • Mysql Explain命令的使用与分析
    mysql explain命令用于显示mysql如何使用索引来处理select语句以及连接表。通过该命令可以分析出查询语句或是表结构的性能瓶颈,从而写出性能更好的SQL语句,通过 expalin 命令我们可...
    99+
    2024-04-02
  • Mysql索引结合explain分析示例
    目录简介1.索引分类聚簇索引为什么选择B+树explain简介 Mysql 在我们项目中使用是非常广的,当我们数据量大的时候,就需要考虑建立索引了,我感觉这也是一种以空间换时间的方式...
    99+
    2024-04-02
  • MYSQL 性能分析器 EXPLAIN 用法实例分析
    本文实例讲述了MYSQL 性能分析器 EXPLAIN 用法。分享给大家供大家参考,具体如下: 使用方法: EXPLAIN SELECT * FROM user; 环境和数据准备 -- 查看 MySQ...
    99+
    2022-05-27
    MYSQL 性能分析器 EXPLAIN
  • Mysql深入探索之Explain执行计划详析
    前言 如何写出效率高的SQL语句,提到这必然离不开Explain执行计划的分析,至于什么是执行计划,如何写出高效率的SQL,本篇文章将会一一介绍。 执行计划 执行计划是数据库根据 SQL 语句和相关表的统计信息作出的...
    99+
    2022-05-26
    mysql explain详解 mysql中explain的用法 mysql索引explain
  • MySQL执行计划explain输出列结果解析
    1) id:每个被独立执行的操作的标识,表示对象被操作的顺序;id值大,先被执行;如果相同,执行顺序从上到下。 2) select_type:查询中每个select子句的类型; 3) table:名字,被操...
    99+
    2024-04-02
  • SQL Server Page结构深入分析
    SQL Server存储数据的基本单元是Page,每一个Page的大小是8KB,数据文件是由Page构成的。在同一个数据库上,每一个Page都有一个唯一的资源标识,标识符由三部分组成:db_id,file_...
    99+
    2024-04-02
  • MySQL中IO问题的深入分析与优化
    目录前言一、业务背景二、分析方法1. MySQL 指标(1)  Redo 写次数(2) Row Operations(3) Buffer Pool 请求次数(4) 慢 SQ...
    99+
    2024-04-02
  • 如何深入分析SQL Server Page结构
    这篇文章将为大家详细讲解有关如何深入分析SQL Server Page结构,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。SQL Server存储数据的基本单...
    99+
    2024-04-02
  • Java编码算法与哈希算法深入分析使用方法
    目录一、编码算法1.什么是编码2.URL编码3.Base64编码二、哈希算法1.概述2.哈希碰撞3.常用哈希算法①.MD5②.SHA-1③.RipeMD-1604.哈希算法的用途三、...
    99+
    2022-11-13
    Java编码算法 Java哈希算法
  • 如何使用MYSQL性能分析器EXPLAIN
    这篇文章主要讲解了如何使用MYSQL性能分析器EXPLAIN,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。使用方法:EXPLAIN SELECT * FROM user...
    99+
    2024-04-02
  • mysql之explain使用详解(分析索引)
    explain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。 使用方法,在select语句前加上explain就可以了,如: ex...
    99+
    2024-04-02
  • mysql优化之慢查询分析+explain命令分析+优化技巧总结
    分析慢查询 1.查看慢SQL是否启用,查看命令:show variables like 'log_slow_queries';  如果结果为ON则是开启了,如果为OFF则表示禁用了。 2.开启...
    99+
    2023-02-18
    mysql优化 mysql慢查询分析 mysqlexplain命令分析 mysql优化技巧总结
  • 深入解析MySQL索引数据结构
    目录概述索引数据结构 二叉树 红黑树 B-Tree B+Tree Hash 索引 InnoDB 索引实现(聚集) 索引文件和数据文件是分离的(非聚集) 聚集索引和非聚集索引 联合/复...
    99+
    2024-04-02
  • Android中pendingIntent与Intent的深入分析
    Android中pendingIntent的深入分析 pendingIntent字面意义:等待的,未决定的Intent。 要得到一个pendingIntent对象,使用方法类...
    99+
    2022-06-06
    Android
  • 深入分析 Golang 与 Ruby 的异同
    go 与 ruby 的主要区别在于:go 是一种静态类型编译语言,支持轻量级并行和高效内存管理,适合编写高并发应用程序;ruby 是一种动态类型解释语言,支持真正的并行但内存管理需手动控...
    99+
    2024-05-12
    golang ruby
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作