今日询问Ai得出的结果,分享一下。
MySQL通过explain关键字返回的表格中,每一个字段表示的含义如下:
- id:SELECT的标识符,每个SELECT都会自动分配一个唯一的标识符。
- select_type:SELECT查询的类型,包括简单查询、联合查询、子查询等。
- table:显示这一行的数据是关于哪张表的。
- partitions:匹配的分区信息。
- type:访问类型,包括system、const、eq_ref、ref、range、index和ALL等。
- possible_keys:显示可能应用在这张表中的索引,一个或多个。查询涉及到的字段上若存在索引,则该索引将被列出。
- key:实际使用的索引,如果没有使用索引,则为NULL。
- key_len:表示索引中使用的字节数,可通过该列计算查询中使用的索引长度。
- ref:显示索引的哪一列被使用了,如果可能的话,是一个常数。
- rows:根据表统计信息及索引选用情况,大致估算出找到所需的记录所需要读取的行数。
- filtered:此列显示此表过滤器条件所过滤掉的数据在总数据量中所占比例。
- Extra:包含不适合在其他列中显示但十分重要的额外信息。
其中,type字段表示访问类型,是最重要也是最容易影响查询性能的字段之一。访问类型从最优到最差依次为:
- system
- const
- eq_ref
- ref
- range
- index
- ALL
其中,type值越小越好。如果type值为ALL,则意味着MySQL将扫描整张表找到匹配行。如果type值为index,则意味着MySQL将扫描整个索引树。如果type值为range,则意味着MySQL将扫描部分索引树。如果type值为ref,则意味着MySQL将根据某个索引查找所有匹配某个单独值的行。如果type值为eq_ref,则意味着MySQL将根据某个唯一索引查找单条记录。如果type值为const,则意味着MySQL将根据主键或唯一索引查找单条记录。如果type值为system,则意味着MySQL将只有一行结果(这是const类型特例)。
参考资料:
全网最全 | MySQL EXPLAIN 完全解读 - 知乎 - 知乎专栏https://zhuanlan.zhihu.com/p/281517471 explain结果每个字段的含义说明 - 简书https://www.jianshu.com/p/8fab76bbf448 MySQL—— MySQL的执行计划详解(Explain) - CSDN博客https://blog.csdn.net/zhouhengzhe/article/details/112272134
MySql高级 EXPLAIN用法和结果分析 - CSDN博客https://blog.csdn.net/why15732625998/article/details/80388236