MySQL中EXPLAIN的解释
EXPLAIN是查看MySQL优化器如何决定执行查询的主要方法,这个功能具有局限性,以为它并总是会说出真相,但是却可以获得最好信息.
学会解释EXPLAIN,你就会了解MySQL优化器是如何工作,你才能去优化MySQL.
如何调用?
只需要在SELECT前面加上EXPLAIN即可.
在语句结尾(;之前)加上\G能够更清晰的查看.
需要说的是EXPLAIN只对SELECT查询作解释,INSERT,UPDATE,DELETE不会哦.
EXPLAIN中的列
- id列一个标识SELECT所属行编号,如果在语句中没有子查询或联合,说明只有一个SELECT,于是这个列显示为1,否则内层的SELECT会顺序编号.
MySQL将SELECT查询分为简单和复杂类型,复杂类型可分为:简单子查询,所谓的派生表(在FROM子句中的子查询),UNION查询.
简单子查询:EXPLAIN SELECT (SELECT `uid` FROM `tips` limit 1) FROM `test_key` WHERE 1
所谓的派生表(在FROM子句中的子查询)EXPLAIN SELECT uid FROM (SELECT uid FROM user) as der.
- select_type列:显示了对应还是简单还是复杂SELECT(如果是后者,则将会是三种复杂类型中的一种).
SIMPLE意味着查询中不包含子查询和UNION.如果查询中包含子查询或UNION,那么最外层的SELECT被标记为PRIMARY(也就是id列为1的)
其他标记:
SUBQUERY,包含在SELECT列表中的子查询(不在FROM子句中)被标记为此;
DERIVED,在FROM子句中的子查询被标记为此;
UNION,在UNION中的第二个和随后的SELECT被标记为此;如EXPLAIN SELECT 1 UNION ALL SELECT 1
UNION RESULT,用来从UNION的临时表检索结果的SELECT标记为UNION RESULT,如EXPLAIN SELECT 1 UNION ALL SELECT 1
- table列:显示对应行正在访问哪个表
当FROM子句中有子查询或UNION时,table列是<derivedN>,其中N是id列对应的值
- type列:就是MySQL决定如何查找表中行(一下从最差到最优排列)
ALL,全表扫描
index,跟全表扫描一样,知识MySQL在扫描表时按索引次序进行而不是行
range,范围扫描,一个有限制的索引扫描,它开始于索引里的某一点,返回匹配这个值域的行(显而易见的范围扫描.即带有BETWEEN或在WHERE子句中带有>的查询,当MySQL使用索引去查找一系列值的时候,如IN()和OR列表
,也为显示的范围扫描)
ref,一种索引访问也叫索引查找,他返回所有匹配某单个值的行,它可能会找到多个符合条件行(EXPLAIN SELECT tipname FROM `tips` WHERE uid=10984)
eq_ref,一种索引查找,他最多只返回一条符合条件的行.这种会在使用主键或者唯一性索引时看到.(EXPLAIN SELECT * FROM `tips` WHERE uid=12)
const和system,当MySQL能对查询的某部分进行优化并将其转换成一个常量时(EXPLAIN SELECT * FROM `tips` WHERE id=5)
NULL,这种访问方式意味着MySQL能在优化阶段分解查询语句,在执行阶段用不着在访问表或者索引(EXPLAIN SELECT max(id),min(id)FROM `tips`)
- possible_keys列:这一列显示了查询可以使用哪些索引,是基于查询访问的列和使用的比较操作符来判断的.
- key列:这一列显示了MySQL决定采用哪个索引来优化对该表的访问
- key_len列:显示MySQL在索引里使用的字节数.举个例子就是在查询中使用到了主键,而主键的数据类型为INT,则为4,SMALLINT则为2
- ref列:显示了之前的表在key列记录的索引中查询值所用到的列或常量.
- row列:显示的是MySQL为了找到所需的值而要读取的行数.
- Extra列:在此显示的是在其他列不适合显示的额外信息
Using index,MySQL将使用覆盖索引,以避免访问表(就是仅仅使用了索引中信息而没有读取表中)
Using where,意味着MySQL服务器将在存储引擎检索行后在进行过滤(将会通过WHERE条件来筛选存储引擎返回的记录)
Using temporary,意味着MySQL在对查询结果排序时会用到一个临时表.
Using filesort,意味着MySQL会对结果使用一个外部索引排序,而不是按索引次序从表里读出来.
Rangechecked for each record(indexmap:N),意味着没有好用的索引,新的索引将在联接的每一行上重新估算,N代表possible_keys列中索引的位图,并且是冗余的.
MySQL中EXPLAIN的解释的更多相关文章
- mysql中explain的用法
mysql中explain的用法 最近在做性能测试中经常遇到一些数据库的问题,通常使用慢查询日志可以找到执行效果比较差的sql,但是仅仅找到这些sql是不行的,我们需要协助开发人员分析问题所在,这就经 ...
- 详解MySQL中EXPLAIN解释命令
Explain 结果解读与实践 基于 MySQL 5.0.67 ,存储引擎 MyISAM . 注:单独一行的"%%"及"`"表示分隔内容,就象分开“第一 ...
- MySQL中EXPLAIN解释命令详解
MySQL中的explain命令显示了mysql如何使用索引来处理select语句以及连接表.explain显示的信息可以帮助选择更好的索引和写出更优化的查询语句. 1.EXPLAIN的使用方法:在s ...
- MySQL中EXPLAIN解释命令 查看索引是否生效
explain显示了mysql如何使用索引来处理select语句以及连接表.可以帮助选择更好的索引和写出更优化的查询语句. 使用方法,在select语句前加上explain就可以了: 如: expla ...
- Mysql中explain命令查看语句执行概况
Mysql中可以使用explain命令查看查询语句的执行方式,使用方法举例:explain + 查询语句 例如:explain select * from user_info 几个重要的字段说明: t ...
- MySQL中explain语句的使用
一.概述 在 MySQL 中,我们可以使用慢查询日志或者 show processlist 命令等方式定位到执行耗时较长的 SQL 语句,在这之后我们可以通过 EXPLAIN或者 DESC 命令获取 ...
- 详解MySQL中EXPLAIN解释命令(转)
explain显示了mysql如何使用索引来处理select语句以及连接表.可以帮助选择更好的索引和写出更优化的查询语句. 使用方法,在select语句前加上explain就可以了: 如: expla ...
- MySQL中EXPLAIN解释命令(转载)
explain显示了mysql如何使用索引来处理select语句以及连接表.可以帮助选择更好的索引和写出更优化的查询语句. 使用方法,在select语句前加上explain就可以了: 如: expla ...
- mysql中explain的type的解释
type -- 连接类型 type意味着类型,这里的type官方全称是“join type”,意思是“连接类型”,这样很容易给人一种错觉觉得必须需要俩个表以上才有连接类型.事实上这里的连接类型并非字面 ...
随机推荐
- .Net配置文件——反射+配置文件存储类型实例
配置文件+反射确实去除了选择语句的繁琐,带来了优美的赶脚! 首先改进了一下类(接上文): ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 ...
- 微软modern.IE网站,多版本IE免费测试工具集
微软今天发布了modern.IE,这是一系列免费的.针对Web 开发者的测试工具和资源集合网站,微软希望以此来帮助开发者更轻松地实现跨 IE 和其他现代浏览器.跨设备的兼容性,其他还有代码检测工具.标 ...
- java.lang.NullPointerException org.apache.jsp.WEB_002dINF.pages.imagecheck.test_jsp._jspInit(test_jsp.java:22)的原因
HTTP Status 500 - type Exception report message description The server encountered an internal error ...
- [PHP] url的pathinfo模式加载不同控制器的实现
使用自动加载和解析url的参数,实现调用到不同的控制器,实现了pathinfo模式和普通的url模式 文件结构: |--Controller |--Index |--Index.php |--Appl ...
- ASP.NET WebAPI 13 Filter
Filter(筛选器)是基于AOP(面向方面编程)的设计,它的作用是Actionr的执行注入额外的逻辑,以达到横切注入的目的. IFilter 在WebAPI中所以的Filter都实现了IFilter ...
- [WP8] ListBox的Item宽度自动填满
[WP8] ListBox的Item宽度自动填满 范例下载 范例程序代码:点此下载 问题情景 开发WP8应用程序的时候,常常会需要使用ListBox作为容器来呈现各种数据集合.但是在ListBox呈现 ...
- SharePoint 2013 Workflow 分布式配置问题记录
SharePoint 2013 发布已经有一段时间,前段事件主要是做财务项目,用到Oracle和HFM,由于从来没了解过这两个软件,把大部分时间用在了学习Oracle和HFM的API,目前对HFM的A ...
- Atitit.atiInputMethod v2词库清理策略工具 q229
Atitit.atiInputMethod v2词库清理策略工具 q229 1.1. Foreigncode 外码清理1 1.2. 垃圾词澄清1 1.1. Foreigncode 外码清理 On ...
- 实验12:Problem F: 求平均年龄
Home Web Board ProblemSet Standing Status Statistics Problem F: 求平均年龄 Problem F: 求平均年龄 Time Limit: ...
- atitit.跨架构 bs cs解决方案. 自定义web服务器的实现方案 java .net jetty HttpListener
atitit.跨架构 bs cs解决方案. 自定义web服务器的实现方案 java .net jetty HttpListener 1. 自定义web服务器的实现方案,基于原始socket vs ...