oracle 索引分支块,深入剖析-Oracle索引分支块的结构

1、每个索引分支块都只有一个lmc,这个lmc指向的分支块/叶子块中的所有索引键值列中的最大值一定小于该lmc所在分支块的所有索引键值列中的最小值;

2、索引分支块的行记录所对应的存储格式为“行头 + 分支块/叶子块的RDBA + col 0 + col 1”,其中col 0为索引键值列,等于该行行头“分支块/叶子块的RDBA”所指向的叶子块中的第一行索引行所对应的数据行的ROWID实例解析通过实例解析Oracle索引分支块的结构

194408127_34_20200708031126755

194408127_35_20200708031126911

/nbstu01/app/oracle/diag/rdbms/nbstest/NBSTEST/trace/NBSTEST_ora_9699378.trc的内容为如下所示:

194408127_36_20200708031127114

194408127_37_20200708031127302

从上述显示内容中我们可以看出,现在索引IDX_T2有如下这三个分支块:

194408127_38_20200708031127693

194408127_61_20200709102536240

我们现在直接来dump上述分支块0x38003c6,dump后的trace文件内容为如下所示:

194408127_39_20200708031127833

194408127_40_2020070803112821

先来看上述显示内容中的第9行记录:

194408127_41_20200708031128177

194408127_42_20200708031128349

上述第9行记录所在叶子块的起止地址为0x380028f:

194408127_43_20200708031128458

上述叶子块的dump内容为如下所示:

194408127_44_20200708031128536

194408127_45_20200708031128786

然后我们再来dump上述叶子块的前一个块(即kdxleprv 58720910=0x380028e);

194408127_46_2020070803112999

也就是说上述第9行记录对应了两个索引行,这两个索引行恰好分布在两个叶子块中,一个在叶子块0x0380028f中,一个在叶子块0x380028e中

194408127_47_20200708031129208.gif

再来看上述分支块的dump内容中的第20行记录:

194408127_48_20200708031129239

194408127_49_20200708031129333

上述第20行记录所在叶子块的起始地址为0x380029a:

194408127_62_20200709102536286

上述叶子块的dump内容为如下所示:

194408127_50_20200708031129583

194408127_51_20200708031129833

然后我们再来dump上述叶子块的前一个块(即58720921=0x3800299);

194408127_52_202007080311305

也就是说上述第20行记录对应了两个索引行,这两个索引行也恰好分布在两个叶子块中,一个在叶子块0x0380029a中,一个在叶子块0x03800299中

再来看上述分支块dump内容中的第230行记录:

因分析过程和结论和上述类似,这里略去。

194408127_47_20200708031129208.gifcol1记录的值为其ROWID头3个byte的实例

194408127_53_20200708031130114

上述分支块的行记录所对应叶子块的dump内容为如下所示:

194408127_54_20200708031130271

194408127_55_20200708031130458

再来dump上述叶子块的前一个块:

194408127_56_20200708031130646

这里上述叶子块的第一行记录所对应的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就可以了。

194408127_47_20200708031129208.gifcol1记录的值为其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内容为如下所示:

194408127_64_20200709032941333

194408127_57_20200708031130943

再来dump上述叶子块的前一个块:

194408127_58_20200708031131146

这里上述叶子块的第一行记录所对应的ROWID为0b 00 0b 6a 00 57,其前一个叶子块的最后一行记录所对应的ROWID为01 43 d1 a7 00 06,这两个ROWID的头1个byte分别为0b和01,已然不同,所以上述分支块的行记录的col1只用记录0b就可以了。常见问题194408127_59_20200708031131255.png

sys.undump存储过程的源码能否提供下?

194408127_60_20200708031131286.png

create or replace procedure undump

(i_vc_input in varchar2) is

/*

功能: 将dump出来的16进制文本内容翻译成其原始文本,目前仅支持ZHS16GBK和AL32UTF8字符集

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值