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

MySQL中如何使用EXPLAIN命令

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

MySQL中如何使用EXPLAIN命令

这篇文章主要为大家展示了“MySQL中如何使用EXPLAIN命令”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL中如何使用EXPLAIN命令”这篇文章吧。

explain显示了mysql如何处理select语句以及连接表。

下面是explain命令的一个例子:

C:\Users\duansf>mysql -u root -p
Enter password: ******
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.5.13 MySQL Community Server (GPL)


Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.


Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.


mysql> use test
Database changed
mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| workinfo       |
+----------------+
1 row in set (0.00 sec)


mysql> explain select * from workinfo\G
*************************** 1. row ***************************
           id: 1
  select_type: SIMPLE
        table: workinfo
         type: ALL
possible_keys: NULL
          key: NULL
      key_len: NULL
          ref: NULL
         rows: 1
        Extra:
1 row in set (0.00 sec)


mysql>

 
1、id
SELECT识别符,这是SELECT查询序列号。这个不重要,查询序号即为sql语句执行的顺序


2、select_type
select类型,它有以下几种值:
simple:它表示简单的select,没有union和子查询
primary:最外面的select,在有子查询的语句中,最外面的select查询就是primary
union:union语句的第二个及以后的子查询
dependent union:UNION中的第二个及以后的子查询语句,取决于外面的查询
union result:UNION的结果
subquery:子查询中的第一个select语句
dependent subquery:依赖于外查询的子查询中的第一个select
derived:子查询衍生出来的表
materialized:物化子查询
uncacheable subquery:不能被缓存,需要重新评估的子查询
uncacheable union:union中第二个及以上的uncacheable subquery中需要重新评估的子查询


3、table
输出的行所用的表


4、type
连接类型
system:表仅有一行,这是const类型的特列,平时不会出现,这个也可以忽略不计
const:表最多有一个匹配行,const用于比较primary key 或者unique索引。因为只匹配一行数据,所以很快。记住一定是用到primary key或者unique,并且只检索出两条数据的情况下才会是const
eq_ref:对于每个来自于前面的表的行组合,从该表中读取一行。这可能是最好的联接类型,除了const类型。它用在一个索引的所有部分被联接使用并且索引是UNIQUE或PRIMARY KEY"。eq_ref可以用于使用=比较带索引的列。
ref:对于每个来自于前面的表的行组合,所有有匹配索引值的行将从这张表中读取。如果联接只使用键的最左边的前缀,或如果键不是UNIQUE或PRIMARY KEY(换句话说,如果联接不能基于关键字选择单个行的话),则使用ref。如果使用的键仅仅匹配少量行,该联接类型是不错的。
fulltext:使用全文索引
ref_or_null:该联接类型如同ref,但是添加了MySQL可以专门搜索包含NULL值的行。在解决子查询中经常使用该联接类型的优化。
index_merge:该联接类型表示使用了索引合并优化方法。在这种情况下,key列包含了使用的索引的清单,key_len包含了使用的索引的最长的关键元素。
unique_subquery:在带有in的子句中用来代替ref
index_subquery:类似于unique_subquery,查询条件
range:给定范围内的检索,使用一个索引来检查行,用到=、<>、>、<、>=、<=、is null、<=>、between、in
ALL:对于每个来自于先前的表的行组合,进行完整的表扫描。如果表是第一个没标记const的表,这通常不好,并且通常在它情况下很差。通常可以增加更多的索引而不要使用ALL,使得行能基于前面的表中的常数值或列值被检索出。
index:该联接类型与ALL相同,除了只有索引树被扫描。这通常比ALL快,因为索引文件通常比数据文件小。(也就是说虽然all和Index都是读全表,但index是从索引中读取的,而all是从硬盘中读的)


5、possible_keys
提示使用哪个索引会在该表中找到行


6、keys
查询实际用到的索引


7、key_len
实际用到的索引长度

8、ref
ref列显示使用哪个列或常数与key一起从表中选择行。

9、rows
显示执行查询的行数,,数值越大越不好,说明没有用好索引

10、Extra
查询语句的额外信息

以上是“MySQL中如何使用EXPLAIN命令”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

免责声明:

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

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

MySQL中如何使用EXPLAIN命令

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

下载Word文档

猜你喜欢

mysql中Explain命令的作用是什么

本篇文章给大家分享的是有关mysql中Explain命令的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、概念explain 用来分析 SELECT 查询语句,开发
2023-06-15

Mysql中explain命令返回参数的具体使用

目录1. explain命令是什么东西?2.explain命令返回列解读explain 是mysql提供的SQL语句查询性能的工具,是我们优化SQL的重要指标手段,要看懂explain返回的结果集就尤为重要,这篇文章主要介绍了MySql e
Mysql中explain命令返回参数的具体使用
2024-09-09

MySQL中EXPLAIN语句如何使用

这篇文章主要介绍了MySQL中EXPLAIN语句如何使用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在MySQL优化的环节上,我们首先需要知道的就是我们当前的这句SQL语句
2023-06-14

SQL中EXPLAIN命令怎么用

这篇文章主要介绍了SQL中EXPLAIN命令怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。explain显示了mysql如何使用索引来处理select语句以及连接表。可
2023-06-08

如何在Mysql中使用Explain调优工具

这篇文章给大家介绍如何在Mysql中使用Explain调优工具,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Explain工具介绍使用EXPLAIN关键字可以模拟优化器执行SQL语句,分析你的查询语句或是结构的性能瓶颈
2023-06-07

编程热搜

目录