如何转储B*Tree索引的分枝结构(转)

http://www.eygle.com/archives/2005/02/ecibtreeeeoaeoe.html

Oracle允许对B*Tree索引进行转储,以显示B*Tree的层次结构。
示例如下:

1.首先选择要研究的索引

SQL> select index_name from user_indexes where index_name='I_BD_INVMANDOC_TS';

INDEX_NAME
------------------------------
I_BD_INVMANDOC_TS


2.找到该索引的object_id
SQL> select object_id from dba_objects where object_name='I_BD_INVMANDOC_TS';

 OBJECT_ID
----------
      6393


3.转储该索引结构
SQL> ALTER SESSION SET EVENTS 'immediate trace name TREEDUMP level 6393';

Session altered.


4.现在是trace文件中的片断
我们可以看到该索引共有三个层次,每个leaf上大约有341条记录.
*** 2005-02-26 10:52:11.458
----- begin tree dump
branch: 0x1403d9c 20987292 (0: nrow: 5, level: 2)
   branch: 0x1403f07 20987655 (-1: nrow: 351, level: 1)
      leaf: 0x1403d9d 20987293 (-1: nrow: 341 rrow: 341)
      leaf: 0x1403d9e 20987294 (0: nrow: 341 rrow: 341)
      leaf: 0x1403d9f 20987295 (1: nrow: 341 rrow: 341)
......
      leaf: 0x1403f00 20987648 (344: nrow: 341 rrow: 341)
      leaf: 0x1403f01 20987649 (345: nrow: 341 rrow: 341)
      leaf: 0x1403f02 20987650 (346: nrow: 341 rrow: 341)
      leaf: 0x1403f03 20987651 (347: nrow: 341 rrow: 341)
      leaf: 0x1403f04 20987652 (348: nrow: 341 rrow: 341)
      leaf: 0x1403f05 20987653 (349: nrow: 341 rrow: 341)
   branch: 0x140406c 20988012 (0: nrow: 350, level: 1)
      leaf: 0x1403f06 20987654 (-1: nrow: 341 rrow: 341)
      leaf: 0x1403f08 20987656 (0: nrow: 341 rrow: 341)
      leaf: 0x1403f0a 20987658 (1: nrow: 341 rrow: 341)
      leaf: 0x1403f0b 20987659 (2: nrow: 341 rrow: 341)
      leaf: 0x1403f0c 20987660 (3: nrow: 341 rrow: 341)
      leaf: 0x1403f0d 20987661 (4: nrow: 341 rrow: 341)
...
      leaf: 0x1404067 20988007 (345: nrow: 341 rrow: 341)
      leaf: 0x1404068 20988008 (346: nrow: 341 rrow: 341)
      leaf: 0x1404069 20988009 (347: nrow: 341 rrow: 341)
      leaf: 0x140406a 20988010 (348: nrow: 341 rrow: 341)
   branch: 0x14041d1 20988369 (1: nrow: 350, level: 1)
      leaf: 0x140406b 20988011 (-1: nrow: 341 rrow: 341)
      leaf: 0x140406d 20988013 (0: nrow: 341 rrow: 341)
      leaf: 0x140406e 20988014 (1: nrow: 341 rrow: 341)
...
      leaf: 0x14041ce 20988366 (347: nrow: 341 rrow: 341)
      leaf: 0x14041cf 20988367 (348: nrow: 341 rrow: 341)
   branch: 0x1404336 20988726 (2: nrow: 351, level: 1)
      leaf: 0x14041d0 20988368 (-1: nrow: 341 rrow: 341)
      leaf: 0x14041d2 20988370 (0: nrow: 341 rrow: 341)
      leaf: 0x14041d3 20988371 (1: nrow: 341 rrow: 341)
 ...
      leaf: 0x1404332 20988722 (347: nrow: 341 rrow: 341)
      leaf: 0x1404333 20988723 (348: nrow: 341 rrow: 341)
      leaf: 0x1404334 20988724 (349: nrow: 341 rrow: 341)
   branch: 0x140446f 20989039 (3: nrow: 308, level: 1)
      leaf: 0x1404335 20988725 (-1: nrow: 341 rrow: 341)
      leaf: 0x1404337 20988727 (0: nrow: 341 rrow: 341)
      leaf: 0x1404338 20988728 (1: nrow: 341 rrow: 341)
      leaf: 0x1404339 20988729 (2: nrow: 341 rrow: 341)
 ...
      leaf: 0x140446c 20989036 (304: nrow: 341 rrow: 341)
      leaf: 0x140446d 20989037 (305: nrow: 341 rrow: 341)
      leaf: 0x140446e 20989038 (306: nrow: 73 rrow: 73)
----- end tree dump


通过这个跟踪可以清楚地看到B*Tree索引的结构,有助于加深对于B*Tree索引的理解。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/756652/viewspace-242193/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/756652/viewspace-242193/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值