• 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  预估结果集的条数,可能不一定完全准确

  • 相关阅读:
    深入Python(一)
    深入Python(二)
    初识Python(五)
    初识Python(一)
    深入Python(三)
    一、MongoDB的下载、安装与部署
    浏览器上的javascript
    javascript中的事件
    扩展方法
    团队项目开题报告
  • 原文地址:https://www.cnblogs.com/hanxue112253/p/8276571.html
Copyright © 2020-2023  润新知