我们来学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列展示的就是与索引列进行等值匹配 的是啥东西
      • 使用等号操作符
      • 使用了索引列
    • 是啥东西呢?
      • 常数
      • 某个列
      • 函数
相关推荐
低音钢琴1 天前
【从零开始构建性能测试体系-08】如何诊断性能瓶颈:从服务器到数据库的全方位分析
服务器·数据库·php
蜡笔小炘1 天前
SQL sever数据库--第三次作业
数据库·sql·oracle
xuejianxinokok1 天前
io_uring 快吗? Postgres 17 与 18 的基准测试
数据库·后端·postgresql
PieroPc1 天前
用Python Streamlit Sqlite3 写一个简单商品管理系统
数据库·python·sqlite·streamlit
SamDeepThinking1 天前
MySQL InnoDB Redo Log简单介绍
mysql
GOATLong1 天前
MySQL内置函数
android·数据库·c++·vscode·mysql
bcgbsh1 天前
数据库分类详解
数据库
立志成为大牛的小牛1 天前
数据结构——二十九、图的广度优先遍历(BFS)(王道408)
数据结构·数据库·学习·程序人生·考研·算法·宽度优先
爬山算法1 天前
Redis(78) 如何设置Redis的缓存失效策略?
数据库·redis·缓存
DemonAvenger1 天前
深入Redis String:从基础到实战,10年经验的后端工程师带你解锁最佳实践
数据库·redis·性能优化