我们来学mysql -- EXPLAIN之ref(原理篇)

EXPLAIN之ref

题记

  • 书接上文《 EXPLAIN之type
  • 2024美国大选已定,川普剑登上铁王座,在此过程中出谋划策的幕僚很重要,是他们决定了最终的执行计划
  • 在《查询成本之索引选择》中提到,explain的输出,就是优化器 (幕僚)选择的执行计划
  • 除了SELECT开头的查询,DELETE、INSERT、UPDATE也都有执行计划,这里只关注SELECT
  • 从输出的计划中可见很多字段,传达了什么样的信息,接下来看ref

ref

  • 首先友情提示,不要和type字段ref值(ref访问方法)弄混淆

  • 和访问方法是有关联的,又不是所有的都有关联

    • 当type是 const
      EXPLAIN SELECT * from ucoding WHERE k2 IN ('6')

    • 当type是 ref
      EXPLAIN SELECT * from ucoding WHERE k1 = '6'

      EXPLAIN SELECT * from ucoding t1 join icoding t2 WHERE t1.k1 = t2.i_k1
      EXPLAIN SELECT * from ucoding t1 join icoding t2 on t1.k1 = UPPER(t2.i_k1)

    • 当 type是 eq_ref、unique_subquery、index_subquery,看执行计划ref列的值,就能知道使用了索引,索引匹配的是啥

  • 见了如上的列子,估计心里有那么点感觉了

    • ref列展示的就是与索引列进行等值匹配 的是啥东西
      • 使用等号操作符
      • 使用了索引列
    • 是啥东西呢?
      • 常数
      • 某个列
      • 函数
相关推荐
初恋叫萱萱3 分钟前
基于CodeRider-Kilo和MySQL开发一款书店管理系统
数据库·mysql·产品运营
图乐aj6 分钟前
MySQL 运维之日常运维篇 二
运维·mysql
Elastic 中国社区官方博客7 分钟前
通过 Elasticsearch 中的 function score query 按利润和受欢迎程度提升电商搜索效果
大数据·数据库·elasticsearch·搜索引擎·全文检索
qq_3663363711 分钟前
mysql-5.7.38-winx64.zip 启动教程(免安装版)
数据库·mysql·adb
不穿格子的程序员13 分钟前
Redis篇5——Redis深度剖析:系统的“隐形杀手”——热Key与大Key问题
数据库·redis·缓存·热key·大key
·云扬·23 分钟前
深入理解MySQL元数据锁(MDL):原理、问题与实践
数据库·mysql
guoyiguang224 分钟前
mysql in 查询 没有限制1000个,默认是sql大小4M大小
数据库·sql·mysql
IT教程资源D25 分钟前
[N_115]基于springboot,vue教务管理系统
mysql·vue·前后端分离·springboot教务系统
镜花水月linyi27 分钟前
执行SELECT/INSERT/UPDATE/DELETE的SQL语句,MySQL流程是怎么样的?
后端·mysql
luoluoal32 分钟前
基于python的des算法的企业用户数据安全软件(源码+文档)
python·mysql·毕业设计·源码