mysql explain分析

通过explain可以知道mysql是如何处理语句,分析出查询或是表结构的性能瓶颈。通过expalin可以得到:

1. 表的读取顺序

2.表的读取操作的操作类型

3.哪些索引可以使用

4. 哪些索引被实际使用

5.表之间的引用

6.每张表有多少行被优化器查询

explain显示字段

1. id :语句的执行顺序标识

2. select_type:使用的查询类型,主要有以下几种查询类型:

1)simple 简单类型

语句中没有子查询或union

2)primary 最外层的select,不是主键

3)union

union是在select 语句中第二个select语句后面所有的select,第一个select 为primary

4)dependent subquery

子查询中内层中第一个select语句

5).  dependent  union

子查询中union且为union中第二个select开始的后面所有select,依赖于外部的结果集。

6). SUBQUERY

7).devived

派生表的查询语句

8). uncacheable subquery

结果集无法缓存的子查询

9). union result

union中合并的结果

3. table 

显示这一步所访问的数据库中表的名称

4. type 

这列很重要,显示了连接使用了哪种类别,有无使用索引。type代表查询执行计划(QEP)中指定的表使用的连接方式。从最好到最差的连接类型为 1.system、2.const、3. eq_reg、4. ref、5. range、6.index、7. all

1) system

system为const一个特例,即表中只有一条记录

2) const

const是在where条件以常量作为查询条件,表中最多有一条记录匹配。由于是常量,所以实际上只需要读一次。

3) eq_reg

最多只会有一条匹配结果,一般是通过主键或是唯一索引来访问。一般会出现在连接查询的语句中。

4)ref

join 语句中被驱动的表索引引用查询。这个值表示所有具有匹配的索引值的行都被用到。

5)range

索引范围扫描

6)index

全索引树被扫描

7) all

全表扫描,效果是最不理想的。

5. possible_keys

查询可以利用的索引,如果没有任何索引可以使用,就会显示成null,这项对内容的优化时索引的调整非常重要。

6.key

从possible_keys中所选择使用的索引

7. key_len

key_len列显示mysql决定使用的键长度,如果键是null,则长度为null。使用的索引长度,一般越短越好。

8. ref 

列出的是通过常量const,或是某个表的某个字段来过滤的。

9.rows

通过系统收集到的统计信息,估计出来的结果集记录条数

10. filtered 列

  在mysql5.1里新加的,在使用explain extended时出现。它显示的是针对表里符合条件的记录数的百分比所做的一个悲观估算值。

filtered列给出了一个百分比的值,这个百分比值和rows 列的值相乘,可以估计出那些将要和QEP 中的前一个表进行连接的行的数目。前一个表就是指id 列的值比当前表的id 小的表。这一列只有在EXPLAIN EXTENDED 语句中才会出现。

11. extra

Extra:查询中每一步实现的额外细节信息,主要可能会是以下内容:

1). Distinct:查找distinct值,所以当mysql找到了第一条匹配的结果后,将停止该值的查询而转为后面其他值的查询; FullscanonNULLkey:子查

询中的一种优化方式,主要在遇到无法通过索引访问null值的使用使用;

2).  ImpossibleWHEREnoticedafterreadingconsttables:MySQLQueryOptimizer通过收集到的统计信息判断出不可能存在结果;

3). Notables:Query语句中使用FROMDUAL或者不包含任何FROM子句;

4). Notexists:在某些左连接中MySQLQueryOptimizer所通过改变原有Query的组成而使用的优化方法,可以部分减少数据访问次数;

5). Rangecheckedforeachrecord(indexmap:N):通过MySQL官方手册的描述,当MySQLQueryOptimizer没有发现好的可以使用的索引的时候,如果

发现如果来自前面的表的列值已知,可能部分索引可以使用。对前面的表的每个行组合,MySQL检查是否可以使用range或index_merge访问方法来索取

行。

6). Selecttablesoptimized away:当我们使用某些聚合函数来访问存在索引的某个字段的时候,MySQLQueryOptimizer会通过索引而直接一次定位到

所需的数据行完成整个查询。当然,前提是在Query中不能有GROUPBY操作。如使用MIN()或者MAX()的时候;

7). Usingfilesort:当我们的Query中包含ORDERBY操作,而且无法利用索引完成排序操作的时候,MySQLQueryOptimizer不得不选择相应的排序算法

来实现。

8).  Usingindex:所需要的数据只需要在Index即可全部获得而不需要再到表中取数据(索引覆盖);

9). Usingindexforgroup-by:数据访问和Usingindex一样,所需数据只需要读取索引即可,而当Query中使用了GROUPBY或者DISTINCT子句的时候,

如果分组字段也在索引中,Extra中的信息就会是Usingindexforgroup-by;

10). Usingtemporary:当MySQL在某些操作中必须使用临时表的时候,在Extra信息中就会出现Usingtemporary。主要常见于GROUPBY和ORDERBY等

操作中。

11). Usingwhere:如果我们不是读取表的所有数据,或者不是仅仅通过索引就可以获取所有需要的数据,则会出现Usingwhere信息;

12). Usingwherewithpushedcondition:这是一个仅仅在NDBCluster存储引擎中才会出现的信息,而且还需要通过打开ConditionPushdown优化功能

才可能会被使用。控制参数为engine_condition_pushdown。

MYSQL:explain分析相关推荐

  1. mysql explain分析

    通过explain可以知道mysql是如何处理语句,分析出查询或是表结构的性能瓶颈.通过expalin可以得到: 1. 表的读取顺序 2.表的读取操作的操作类型 3.哪些索引可以使用 4. 哪些索引被 ...

  2. mysql explain 分析中select_type列解释

  3. mysql extended_explain之三:MYSQL EXPLAIN语句的extended 选项学习体会,分析诊断工具之二...

    MySQL 的explain命令有一个extended选项,我想可以很多人都没有注意,因为它对命令的输出结果没有任何改变,只是增加了一个warning.这个 warning中显示了MySQL对SQL的 ...

  4. MySQL性能分析及explain的使用

    MySQL性能分析及explain用法的知识是本文我们主要要介绍的内容,接下来就让我们通过一些实际的例子来介绍这一过程,希望能够对您有所帮助. 1.使用explain语句去查看分析结果 如explai ...

  5. mysql 查询慢 分析_MySQL优化:定位慢查询的两种方法以及使用explain分析SQL

    一条SQL查询语句在经过MySQL查询优化器处理后会生成一个所谓的执行计划,这个执行计划展示了具体执行查询的方式,比如多表连接的顺序是什么,对于每个表采用什么访问方法来具体执行查询等等. 本章的内容就 ...

  6. MySQL 索引分析除了 EXPLAIN 还有什么方法?

    作者 | adrninistrat0r 责编 | 夕颜 出品 | CSDN(ID:CSDNnews) 前言 对于非数据库开发人员而言,难以对MySQL源码进行分析或调试,接近一个黑盒,但MySQL提供 ...

  7. [转]Mysql explain用法和性能分析

    本文转自:http://blog.csdn.net/haifu_xu/article/details/16864933  from  @幸福男孩 MySQL中EXPLAIN解释命令是显示mysql如何 ...

  8. mysql 执行效率命令_MySQL优化--explain 分析sql语句执行效率

    MySQL优化--explain 分析sql语句执行效率 explain 命令 explain 命令在解决数据库性能上市第一推荐使用命令,大部分的性能问题可以通过此命令来简单解决,explain可以用 ...

  9. mysql explain key为空_MySQL中explain的使用以及性能分析

    原标题:MySQL中explain的使用以及性能分析 MySQL 提供了一个 EXPLAIN 命令, 它可以对 SELECT 语句进行分析, 并输出 SELECT 执行的详细信息, 以供开发人员针对性 ...

最新文章

  1. jq选中单选框后文本框不可编辑_打开速度最快最强大的PDF免费工具,编辑+阅读功能一体...
  2. netty实现mysql协议_基于Netty模拟解析Binlog
  3. meta name id class 标签的区别
  4. 使用Joson的格式字符串在Socket中通讯时数据格式的转换
  5. [css] 请使用css3实现图片的平滑转换
  6. mysql 最基础的日常操作
  7. logstash grok切分nginx日志
  8. HTML、CSS、JavaScript网页制作从入门到精通 (刘西杰) pdf扫描版彩色版​
  9. 数据分析:使用Imblearn处理不平衡数据(过采样、欠采样)
  10. 关于数据中台,扎克伯格和马化腾做法不同
  11. mysql 名次语法规则_Mysql排名问题
  12. python爬虫分析百度文库、道客巴巴、豆丁网获取图片链接
  13. mongoVUE查询
  14. Android studio打开机智云APP(自动生成)
  15. 深度linux网卡配置,Deepin 15.11 命令行配置静态IP
  16. 计算机专业对体重有要求吗,毕业季|@毕业生,你知道计算机学院有多重吗?
  17. 【翻译】HCP: A Flexible CNN Framework for Multi-Label Image Classification
  18. 90%的 CTO 都做不好绩效管理
  19. 新款苹果手机_售价千元!苹果今日推出新款手机壳,买吗
  20. 用Python来检测微信好友是否拉黑你

热门文章

  1. 用scheme重写Python的三大函数map reduce 和filter
  2. Linux查看内存使用情况
  3. 利用js实现table增加一行
  4. Mac OS 错误代码 -8072的可行解决方法
  5. 南通市交巡警支队同城异地容灾备份系统项目中标结果公告
  6. 转载:Hyper-V管理器和SCVMM 2008 R2区别
  7. 几种网络负载均衡方法比较
  8. 爬取最好大学网站大学排名
  9. 论文笔记:GVCNN: Group-View Convolutional Neural Networks for 3D Shape Recognition
  10. 论文笔记:DGCNN(EdgeConv)