zoukankan      html  css  js  c++  java
  • Mysql中的explain和desc

    查询分析器 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等

  • 相关阅读:
    openmediavault 5.5.23 安装插件失败的解决方案
    qt下载地址
    qt 5.12 增加 mysql驱动
    选基金标准
    关注几个基金
    调仓的几个问题
    要读的书
    ubuntu 20.04 LTS 安装webmin
    set的常见用法
    斜率优化dp([HNOI2008]玩具装箱)
  • 原文地址:https://www.cnblogs.com/lz0925/p/10761923.html
Copyright © 2011-2022 走看看