深入剖析-Oracle索引分支块的结构
作者介绍
崔华 网名 dbsnake
Oracle ACE Director,ACOUG 核心专家
重要结论
1、每个索引分支块都只有一个lmc,这个lmc指向的分支块/叶子块中的所有索引键值列中的最大值一定小于该lmc所在分支块的所有索引键值列中的最小值;
2、索引分支块的行记录所对应的存储格式为“行头 + 分支块/叶子块的RDBA + col 0 + col 1”,其中col 0为索引键值列,等于该行行头“分支块/叶子块的RDBA”所指向的叶子块中的第一行索引行所对应的数据行的ROWID
实例解析
通过实例解析Oracle索引分支块的结构
/nbstu01/app/oracle/diag/rdbms/nbstest/NBSTEST/trace/NBSTEST_ora_9699378.trc的内容为如下所示:
从上述显示内容中我们可以看出,现在索引IDX_T2有如下这三个分支块:
我们现在直接来dump上述分支块0x38003c6,dump后的trace文件内容为如下所示:
先来看上述显示内容中的第9行记录:
上述第9行记录所在叶子块的起止地址为0x380028f:
上述叶子块的dump内容为如下所示:
然后我们再来dump上述叶子块的前一个块(即kdxleprv 58720910=0x380028e);
也就是说上述第9行记录对应了两个索引行,这两个索引行恰好分布在两个叶子块中,一个在叶子块0x0380028f中,一个在叶子块0x380028e中
再来看上述分支块的dump内容中的第20行记录:
上述第20行记录所在叶子块的起始地址为0x380029a:
上述叶子块的dump内容为如下所示:
然后我们再来dump上述叶子块的前一个块(即58720921=0x3800299);
也就是说上述第20行记录对应了两个索引行,这两个索引行也恰好分布在两个叶子块中,一个在叶子块0x0380029a中,一个在叶子块0x03800299中
再来看上述分支块dump内容中的第230行记录:
因分析过程和结论和上述类似,这里略去。
col1记录的值为其ROWID头3个byte的实例
上述分支块的行记录所对应叶子块的dump内容为如下所示:
再来dump上述叶子块的前一个块:
这里上述叶子块的第一行记录所对应的ROWID为01 43 d1 fd 00 2b,其前一个叶子块的最后一行记录所对应的ROWID为01 43 d0 11 00 91,这两个ROWID的头3个byte分别为01 43 d1和01 43 d0,已然不同,所以上述分支块的行记录的col1只用记录01 43 d1就可以了。
col1记录的值为其ROWID头1个byte的实例
row#18[7464] dba: 184552472=0xb000c18 col 0; len 20; (20): 2f 31 62 39 34 37 31 65 38 5f 53 69 67 6e 61 74 75 72 65 31 col 1; len 1; (1): 0b
上述分支块的行记录所对应叶子块的dump内容为如下所示:
再来dump上述叶子块的前一个块:
这里上述叶子块的第一行记录所对应的ROWID为0b 00 0b 6a 00 57,其前一个叶子块的最后一行记录所对应的ROWID为01 43 d1 a7 00 06,这两个ROWID的头1个byte分别为0b和01,已然不同,所以上述分支块的行记录的col1只用记录0b就可以了。
常见问题
sys.undump存储过程的源码能否提供下?
create or replace procedure undump
(i_vc_input in varchar2) is
/*
功能: 将dump出来的16进制文本内容翻译成其原始文本,目前仅支持ZHS16GBK和AL32UTF8字符集 作者: dbsnake 创建日期:2010-11-30
输入参数: i_vc_input: 输入的dump出来的16进制文本内容
输出参数: 无
输入输出参数: 无
调用到的存储过程: 无
sys.cdba()是否是系统自带的
不是,CDBA的源码如下:
关于oracle自定义外连接”(+)” 书中写的关于full outer join的等价改写:
您提到Oracle断然不会采用这样的等价改写,而是通过如下的改写:
通过这两种改写方式得到的结果是一致的,并查看了两种改写的执行计划,只是在第一种方式中多了union的排序操作,是因为这个原因吗?
排序只是union的副作用,这里为什么用union来模拟是因为我需要union所带来的“去重”
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- ANDROID BottomNavigationBar底部导航栏的实现示例
- Android实现时间倒计时功能
- Android开发基于Drawable实现圆角矩形的方法
- Android开发中滑动分页功能实例详解
- Android登录注册功能 数据库SQLite验证
- CMQ消费者报错,无法获取本机ip地址问题排查
- 腾讯云TKE-Metrics-Server案例: TKE中自建Metrics-Server问题
- (建议收藏)关于JS事件循环, 这一篇就够啦
- TensorFlow2 开发指南 | 02 回归问题之汽车燃油效率预测
- 腾讯云TKE-Ingress案例: TKE-Ingress与Nginx-Ingress共存
- 玩转Kotlin 彻底弄懂Lambda和高阶函数
- leetcode之仅仅反转字母
- 3分钟短文:Laravel的“南天门”,过滤掉七七八八的数据
- 【1024,Serverless】maimai_DX 查分器
- TRTC/MLVB/IM案例:SDK用户日志提取与管理的一种实现方案