查询分析器 desc 和 explain 作用基本一样,explain速度快一点
 explain 一条SQL语句出出现以下参数, 其中id,select_type,table 用于定位查询,表示本行参数所对应的SQL查询部分

- id
  SELECT 识别符,这是SELECT的查询序列号,不重要,需要注意的是,不要把id当成执行顺序,这并不准确
- select_type
  可以分为以下几种:
1、 SIMPLE: 指示非子查询和union的简单查询。

select * from class

2、PRIMARY:指示在有子查询的语句中最外面的select, 主查询。

select * from class where class_id in (select class_id from student)

3、UNION:指示使用union语句的第二个或者后面的select。

select name from teachers union select name from students 

4、DEPENDENT UNION: 子查询union语句的第二个或者后面的select。
5、UNION RESULT: union语句的结果集

select * from class where class_id in (select class_id from teachers union select class_id from students);

6、SUBQUERY: 子查询中的语句, 与union相反理解就行了。
7、DEPENDENT SUBQUERY: 子查询中的第一个语句。

select * from class where class_id in (select class_id from students)

8、DERIVED: 派生表的SELECT(FROM子句的子查询)。

select * from (select class_id,class_name from class)

- table
  就是表名,本行记录对应查询所应用的表。可以通过table表名帮助定位查询。
  使用explain时,有时table字段显示的并不是表名, 而是derived2 或 derived3等等。。。即derived X 代表的是id为X的查询所得到的结果集。例如:

EXPLAIN
SELECT so.storeorder_id,so.storeorder_sn,si,stores_name
from ec_stores_order so
INNER JOIN
(SELECT stores_id, stores_name from ec_stores_info where stores_creatorid=2) si
on so.store_id=si.stores_id

  explain该语句就会得到 derived 2 的table
- partitions
- type(重点)
  连接类型。查询效率的关键,下面按照从最佳类型到最坏类型进行排序
  从最好到最差的连接类型为const、eq_ref、ref、range、index和all。
1、system

  存在于手册中(没怎么见过),最好的连接类型,时候const联接类型的一个特例。
2、const

   表最多有一个匹配行,它将在查询开始时被读取。因为仅有一行,在这行的列值可被优化器剩余部分认为是常数。const表很快,因为它们只读取一次! 即在查询主键索引或是唯一索引时使用。

select * from table where id=1 //主键查询

3、eq_ref

   在连接查询时,连接字段使用主键或是唯一索引时被使用,很常见
4、ref

  与eq_ref相对,在连接查询时,连接字段使用非主键或是唯一索引的普通索引、单列索引或是组合索引的左前缀时被使用,该连接方式可以在索引列范围查询(< = >)时被使用
  ref,使用非唯一索引扫描或者唯一索引的前缀扫描,返回匹配某个单独值的记录行。
5、ref_or_null
  连接的索引列中有null值,ref就会变成这个
6、index_merge
  该联接类型表示使用了索引合并优化方法。在这种情况下,key列包含了使用的索引的清单,key_len包含了使用的索引的最长的关键元素。
7、unique_subquery
  该类型替换了IN子查询。
  unique_subquery是一个索引查找函数,可以完全替换子查询,效率更高。只适用于主键或唯一索引。
8、index_subquery
  该联接类型类似于unique_subquery。可以替换IN子查询,但只适合非唯一索引。
9、range
  只检索给定范围的行,使用一个索引来选择行。key列显示使用了哪个索引。key_len包含所使用索引的最长关键元素。在该类型中ref列为NULL。
  当使用=、<>、>、>=、<、<=、IS NULL、<=>、BETWEEN或者IN操作符,用常量比较关键字列时,可以使用range。
10、index
  该联接类型与ALL相同,除了只有索引树被扫描。这通常比ALL快,因为索引文件通常比数据文件小。
  当查询只使用作为单索引一部分的列时,MySQL可以使用该联接类型。(会扫描整棵索引树)
11、ALL
  没有用到索引,将扫描全表记录,应极力避免。
- possible_keys
  可能能用到的索引,没太大卵用~
- key(关键)
  用到的索引名,关键。查询效率与索引引用息息相关
- key_len
  MySQL使用的索引长度
- ref
  如果是使用的常数等值查询,这里会显示const,如果是连接查询,被驱动表的执行计划这里会显示驱动表的关联字段,如果是条件使用了表达式或者函数,或者条件列发生了内部隐式转换,这里可能显示为func
引用到的上一个表的列
- rows
  显示查询扫描的行数,显然数据越小越好
- filtered
  表示存储引擎返回的数据在server层过滤后,剩下多少满足查询的记录数量的比例,注意是百分比,不是具体记录数。
- Extra
  查询的详细信息,包含所有其它操作,列如
  Distinct,using,index,using where,Using union等

Mysql中的explain和desc的更多相关文章

  1. MySQL查询分析器EXPLAIN或DESC

    转载:http://chenzehe.iteye.com/blog/1682081 MySQL可以通过EXPLAIN或DESC来查看并分析SQL语句的执行情况,如下需要计算2006年所有公司的销售额, ...

  2. 详解 MySQL 中的 explain

    来源:persister 链接:http://www.blogjava.net/persister/archive/2008/10/27/236813.html 在 explain的帮助下,您就知道什 ...

  3. 如何看MySql执行计划explain(或desc)

    简介 MySQL 提供了一个 EXPLAIN 命令, 它可以对 SELECT 语句进行分析, 并输出 SELECT 执行的详细信息, 以供开发人员针对性优化.EXPLAIN 命令用法十分简单, 在 S ...

  4. MySQL中的EXPLAIN

    使用EXPLAIN加上SELECT语句可以获取优化器的查询执行计划 MySQL会在查询上设置一个标记,当执行查询时,这个标记会返回关于在执行计划中每一步的信息,而不是执行它.它会返回一行或多行信息,一 ...

  5. 在MySQL中使用explain查询SQL的执行计划

    1.什么是MySQL执行计划 要对执行计划有个比较好的理解,需要先对MySQL的基础结构及查询基本原理有简单的了解. MySQL本身的功能架构分为三个部分,分别是 应用层.逻辑层.物理层,不只是MyS ...

  6. 如何在MySQL中使用explain查询SQL的执行计划?

    1.什么是MySQL执行计划 要对执行计划有个比较好的理解,需要先对MySQL的基础结构及查询基本原理有简单的了解. MySQL本身的功能架构分为三个部分,分别是 应用层.逻辑层.物理层,不只是MyS ...

  7. 使用MySQL中的EXPLAIN解释命令来检查SQL

    我们看到许多客户的系统因为SQL及数据库设计的很差所以导致许多性能上的问题,这些问题不好解决,但是可以采用一套简单的策略来检查生产系统,发现并纠正一些共性问题. 很显然,您应该尽最大努力设计出最好的数 ...

  8. MySQL中EXPLAIN解释命令 查看索引是否生效

    explain显示了mysql如何使用索引来处理select语句以及连接表.可以帮助选择更好的索引和写出更优化的查询语句. 使用方法,在select语句前加上explain就可以了: 如: expla ...

  9. MySQL中EXPLAIN解释命令详解

    MySQL中的explain命令显示了mysql如何使用索引来处理select语句以及连接表.explain显示的信息可以帮助选择更好的索引和写出更优化的查询语句. 1.EXPLAIN的使用方法:在s ...

随机推荐

  1. 《前端之路》之三 数组的属性 && 操作方法(下)

    咱们 接着上篇来讲- 7.slice() 从某个已有的数组返回选定的元素 经常用来将类数组转化成数组,这样做一方面可以利用现有的数组方法更加方便的处理,另一方面是处于性能的考虑 var f = fun ...

  2. 五行Python代码教你用微信来控制电脑摄像头

    如果说强大的标准库奠定了Python发展的基石,丰富的第三方库则是python不断发展的保证.今天就来通过itchart库来实现通过微信对电脑的一些操作. 一.安装库 安装itchat itchat ...

  3. 【Python3爬虫】为什么你的博客没人看呢?

    我相信对于很多爱好和习惯写博客的人来说,如果自己的博客有很多人阅读和评论的话,自己会非常开心,但是你发现自己用心写的博客却没什么人看,多多少少会觉得有些伤心吧?我们今天就来看一下为什么你的博客没人看呢 ...

  4. Docker进阶之九:Dockerfile 及 通过Dockerfile搭建lnmp

    一.Dockerfile指令 指令 描述 指令 描述 FROM 构建的新镜像是基于哪个镜像 例如:FROM centos:6 COPY 拷贝文件或目录到镜像,用法同上例如:COPY ./start.s ...

  5. Spring Boot 2.X 如何优雅的解决跨域问题?

    一.什么是源和跨域 源(origin)就是协议.域名和端口号.URL由协议.域名.端口和路径组成,如果两个URL的协议.域名和端口全部相同,则表示他们同源.否则,只要协议.域名.端口有任何一个不同,就 ...

  6. Spring Cloud 微服务开发系列整理

    Spring Boot 系列精选 Spring Boot 自定义 starter Spring Boot 整合 mybatis-plus Spring Boot 整合 spring cache Spr ...

  7. Java 8中Stream API学习笔记

    1)函数式编程的优势和劣势分别是什么?优势:①不可变性 ②并行操作 ③执行顺序更灵活 ④代码更加简洁纯粹的函数式编程,变量具有不可变性,同一个参数不会在不同场景下得出不同的结果,因此大大增强了系统的稳 ...

  8. Where Can I Download Full Installers for WebLogic Server

    Where can I download full installers for the different versions of WebLogic Server (WLS)? Full insta ...

  9. AsyncTask机制

    AsyncTask可以让我们更容易地使用UI线程.它允许执行后台操作,并把结果发布到UI线程上,而不需要操作线程或Handler.AsyncTask被设计成一个和Thread.Handler相关的一个 ...

  10. Nginx设置Https反向代理,指向Docker Gitlab11.3.9 Https服务

    目录 目录 1.GitLab11.3.9的安装 2.域名在阿里云托管,申请免费的1年证书 3.Gitlab 的 https 配置 4.Nginx 配置 https,反向代理指向 Gitlab 配置 目 ...