Mysql查询语句Explain解释

MySQL的EXPLAIN关键字用于分析SQL查询的执行计划,涉及字段如id、select_type、type、key和rows等,其中type字段对查询性能影响显著,最佳到最差的顺序为system>const>eq_ref>ref>range>index>ALL。理解这些信息能帮助优化查询效率。
摘要由CSDN通过智能技术生成

今日询问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字段表示访问类型,是最重要也是最容易影响查询性能的字段之一。访问类型从最优到最差依次为:

  1. system
  2. const
  3. eq_ref
  4. ref
  5. range
  6. index
  7. 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博客icon-default.png?t=N4P3https://blog.csdn.net/why15732625998/article/details/80388236

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值