zoukankan      html  css  js  c++  java
  • Mysql的执行计划各个参数详细说明

    执行计划各个参数的说明

    1、id 主要是用来标识sql的执行顺序,如果没有子查询,一般来说id只有一个,执行顺序也是从上到下

    2、select_type 每个select子句的类型

      a:  simple 查询中不包含任何子查询或者union

      b:  primary 查询中包含了任何复杂的子部分,最外层的就会变为primary

      c:  subquery 在selecth或者where中包含了子查询

      d:  derived  在from中包含了子查询

      e: union 如果第二个select 出现在union之后,则被标记为union,如果union包含在from子句的子查询中,外层select会被标记成derived

      f:union  result 从 union表中获取结果的select

    3、type 是指mysql在表中找到所需行的方式,也就是访问行的类型。从a开始效率上升

      a :  (All   全表扫描)      b   (index 会根据索引树进行遍历)  c (rang 根据索引范围扫描,返回匹配值域的行)  d:(ref 非唯一性索引扫描,返回匹配某个单独值的所有行。一般是指多列的唯一索引中的某一列)       e (eq_ref 唯一性索引扫描。表中只有一条与之匹配) f (const、system 主要针对查询中有常量的情况,如果结果中只有一行,会变成System)  g (null即不走表 也不走索引)

    4、possible_keys  预估计了mysql能为当前查询选择的索引。这个字段是完全独立于执行计划中输出的表的顺序。意味着在实际查询中,可能用不到这些索引。如果该字段为null则意味着没有可使用的索引。这个时候你可以考虑为where后面的字段加上索引

    5、key 这个字段表示mysql真实使用的索引。如果mysql优化过程中没有加索引,可以强制加索引

    6、key_len 顾名思义就是索引长度字段。表示mysql使用的索引的长度

    7、ref 这个字段一般是指一些常量用于选择过滤

    8、rows  预估结果集的条数,可能不一定完全准确

  • 相关阅读:
    [译]Stairway to Integration Services Level 3
    [译]SSRS 报表版本控制
    java was started but exit code =-805306369
    There is no session with id XXX
    spring 线程安全
    navicat远程连接阿里云ECS上的MYSQL报Lost connection to MySQL server at 'reading initial communication packet'
    navicat链接阿里云mysql报80070007: SSH Tunnel: Server does not support diffie-hellman-group1-sha1 for keyexchange
    eclipse中的tomca的编辑页面server location灰色
    tomcat tomcat-user.xml被还原
    java元注解
  • 原文地址:https://www.cnblogs.com/hanxue112253/p/8276571.html
Copyright © 2011-2022 走看看