explain 语句详解

explain 写在 select 前,如下

mysql> explain select * from user_info where id = 2\G

*************************** 1. row ***************************

id: 1

select_type: SIMPLE

table: user_info

partitions: NULL

type: const

possible_keys: PRIMARY

key: PRIMARY

key_len: 8

ref: const

rows: 1

filtered: 100.00

Extra: NULL

1 row in set, 1 warning (0.00 sec)

id: SELECT 查询的标识符. 每个 SELECT 都会自动分配一个唯一的标识符.

select_type: SELECT 查询的类型.

table: 查询的是哪个表

partitions: 匹配的分区

type: join 类型

possible_keys: 此次查询中可能选用的索引

key: 此次查询中确切使用到的索引.

ref: 哪个字段或常数与 key 一起被使用

rows: 显示此查询一共扫描了多少行. 这个是一个估计值,当然是越小越好

filtered: 表示此查询条件所过滤的数据的百分比

extra: 额外的信息

select_type 取值

SIMPLE, 表示此查询不包含 UNION 查询或子查询

PRIMARY, 表示此查询有 UNION,并且是最外层的查询。

UNION, 表示此查询是 UNION 的第二或随后的查询

DEPENDENT UNION, UNION 中的第二个或后面的查询语句, 取决于外面的查询

UNION RESULT, UNION 的结果

SUBQUERY, 子查询中的第一个 SELECT

DEPENDENT SUBQUERY: 子查询中的第一个 SELECT, 取决于外面的查询. 即子查询依赖于外层查询的结果.

type 取值

type 字段比较重要, 它提供了判断查询是否高效的重要依据依据. 通过 type 字段, 我们判断此次查询是 全表扫描 还是 索引扫描 等.

system: 表中只有一条数据. 这个类型是特殊的 const 类型.

const: 针对主键或唯一索引的等值查询扫描, 最多只返回一行数据. const 查询速度非常快, 因为它仅仅读取一次即可.

eq_ref: 此类型通常出现在多表的 join 查询, 表示对于前表的每一个结果, 都只能匹配到后表的一行结果. 并且查询的比较操作通常是 =, 查询效率较高.

ref: 此类型通常出现在多表的 join 查询, 针对于非唯一或非主键索引, 或者是使用了 最左前缀 规则索引的查询。还有我发现查询分区表的所有分区的主键也会出现这个。

range: 表示使用索引范围查询, 通过索引字段范围获取表中部分数据记录. 这个类型通常出现在 =, <>, >, >=, , BETWEEN, IN() 操作中。当 type 是 range 时, 那么 EXPLAIN 输出的 ref 字段为 NULL, 并且 key_len 字段是此次查询中使用到的索引的最长的那个.

index: 表示全索引扫描(full index scan), 和 ALL 类型类似, 只不过 ALL 类型是全表扫描, 而 index 类型则仅仅扫描所有的索引, 而不扫描数据。index 类型通常出现在 所要查询的数据直接在索引树中就可以获取到, 而不需要扫描数据. 当是这种情况时, Extra 字段 会显示 Using index。比如说 select id from xxtable

ALL: 表示全表扫描, 这个类型的查询是性能最差的查询之一. 通常来说, 我们的查询不应该出现 ALL 类型的查询, 因为这样的查询在数据量大的情况下, 对数据库的性能是巨大的灾难. 如一个查询是 ALL 类型查询, 那么一般来说可以对相应的字段添加索引来避免.

不同的 type 类型的性能关系如下:

ALL < index < range ~ index_merge < ref < eq_ref < const < system

ALL 类型因为是全表扫描, 因此在相同的查询条件下, 它是速度最慢的.而 index 类型的查询虽然不是全表扫描, 但是它扫描了所有的索引, 因此比 ALL 类型的稍快.后面的几种类型都是利用了索引来查询数据, 因此可以过滤部分或大部分数据, 因此查询效率就比较高了.

extra 取值

Using index: "覆盖索引扫描", 表示查询在索引树中就可查找所需数据, 不用扫描表数据文件, 往往说明性能不错

Using where Using index: 查询的列被索引覆盖,并且where筛选条件是索引列之一,但是不是索引的列,不是前导列。意味着无法直接通过索引查找来查询到符合条件的数据

Using index condition: 需要回表查询,查询的列不全在索引中。意味着查询列的某一部分无法直接使用索引。

Using where: 需要回表查询,查询的列未被索引覆盖,where 筛选条件非索引列。意味着也就是没有可用的索引查找,当然这里也要考虑索引扫描+回表与表扫描的代价。

Using filesort: 当 Extra 中有 Using filesort 时, 表示 MySQL 需额外的排序操作, 不能通过索引顺序达到排序效果. 一般有 Using filesort, 都建议优化去掉, 因为这样的查询 CPU 资源消耗大.

Using temporary: 查询有使用临时表, 一般出现于排序, 分组和多表 join 的情况, 查询效率不高, 建议优化.

mysql explain语句_Mysql explain 语句详解相关推荐

  1. 引导mysql执行计划_Mysql执行计划详解

    --歌手表 CREATE TABLE`singer` ( `id`int(11) unsigned NOT NULL, `update_time`datetime DEFAULT NULL, `nam ...

  2. mysql.user表_mysql.user表详解

    GRANT语法: GRANT 权限 ON 数据库.* TO 用户名@'登录主机' IDENTIFIED BY '密码' 权限: ALL,ALTER,CREATE,DROP,SELECT,UPDATE, ...

  3. mysql 笔试题_MySQL笔试题详解(一)(中等难度)

    有一位学生在找数据分析工作的时候,遇到一个笔试题,内容如下: 现有注册用户表table_user,有两个字段:user_id(用户id).reg_tm(注册时间).有订单表table_order,有三 ...

  4. mysql关系数据库引擎_MySQL数据库引擎详解

    作为Java程序员,MySQL数据库大家平时应该都没少使用吧,对MySQL数据库的引擎应该也有所了解,这篇文章就让我详细的说说MySQL数据库的Innodb和MyIASM两种引擎以及其索引结构.也来巩 ...

  5. mysql autoenlist默认_mysql连接参数详解

    通常数据库连接字符串为: Database=dbname;Data Source=192.168.1.1;Port=3306;User Id=root;Password=****;Charset=ut ...

  6. mysql 插入加锁_Mysql加锁过程详解(9)-innodb下的记录锁,间隙锁,next-key锁

    你需要知道的 之前我们介绍了排他锁,其实innodb下的记录锁(也叫行锁),间隙锁,next-key锁统统属于排他锁. 行锁 记录锁其实很好理解,对表中的记录加锁,叫做记录锁,简称行锁. 生活中的间隙 ...

  7. mysql数据库迁徙_mysql数据迁徙详解

    数据迁徙是每个后端都会遇到的工作之一,本文介绍了一些常见的数据迁徙方法与工具 mysqldump:数据结构不变的数据迁徙 导出数据 mysqldump -u root -p DATABASE_NAME ...

  8. mysql主从配置_MySQL主从配置详解

    主服务器数据库的每次操作都会记录在其二进制文件mysql-bin.xxx(该文件可以在mysql目录下的data目录中看到)中,从服务器的I/O线程使用专用账号登录到主服务器中读取该二进制文件,并将文 ...

  9. mysql skip用法_MySQL性能参数详解之Skip-External-Locking参数介绍

    MySQL的配置文件my.cnf中默认存在一行skip-external-locking的参数,即"跳过外部锁定".根据MySQL开发网站的官方解释,External-lockin ...

  10. mysql limit 算法_MySQL的Limit详解

    问题:数据库查询语句,如何只返回一部分数据? Top子句 TOP 子句用于规定要返回的记录的数目.对于拥有数千条记录的大型表来说,TOP 子句是非常有用的. 在SQL Server数据库中语法为: S ...

最新文章

  1. 全民学英语,VIPKID、51Talk、伴鱼、阿卡索们还好做么?
  2. linux下的arm仿真,使用QEMU仿真ARM Linux系统
  3. 满分最优解法:1007 素数对猜想 (20分)
  4. php 路径 函数不存在,php目录不存在是怎么判断的
  5. Android之BottomNavigationView实现底部按钮水纹波效果
  6. java boolean if_Java if(boolean)和if(boolean=true)区别解析
  7. Docker服务启动时报错:Job for docker.service failed because the control process exited with error
  8. EasyUI组件使用
  9. 履带式机器人与轮式机器人的异同分析
  10. Atitit 发帖机系列(8)  词法分析器v5 版本新特性说明)
  11. 基于AE+C#实现在TOCControl中实现指定图层删除
  12. Cplex入门教程(二)
  13. OTA频发的“大数据杀熟”,想要治你不容易?
  14. 宋星专访:一条特立独行的数据私有化之路
  15. go语言连接远程服务器
  16. 第3章-2 查验身份证
  17. 导弹发射-河南省第九届省赛D题
  18. 少儿Python编程2-计算机和信息处理
  19. 计算机国二表情包,哈哈哈!设计师专用表情包合集(二)
  20. 用DP解决排列组合问题

热门文章

  1. PE文件格式详解(二)
  2. 陈敏敏-130242014024-实验一
  3. sql server数据库实现保留指定位数小数的函数
  4. Hammer.js移动端触屏框架的使用
  5. CuteEditor—Html在线编辑器的领航者,超强的asp.net编辑器控件
  6. javascript --- 将DOM结构转换成虚拟DOM 虚拟DOM转换成真实的DOM结构
  7. 算法 --- 二叉树查找树的先序(中序、后序)遍历的js实现
  8. 【QQ输入法】QQ输入法-剪切板 释放内存
  9. 2017网易内推编程题(判断单词):解答代码
  10. 获取android手机的屏幕分辨率 android开发