5.Oracle BBED解析数据块——BBED基本使用三
欢迎转载,转载请标明出处: http://blog.csdn.net/notbaron/article/details/50572024
Dump命令将块的内存DUMP到屏幕上。可以配合/v参数来产生更多的输出。
Dump的DBA,FILENAME,FILE,BLOCK,OFFSET可以再命令中设置。
如果没有指定,当前文件,块和OFFSET会被DUMP。 DUMP的大小收到set count的限制。
例如DUMP 文件13,块号12,偏移0 ,如下:
BBED> dump /v dba 13,12 offset 0 count128
File: /oradata/tpcc1.dbf (13)
Block: 12 Offsets: 0 to 127 Dba:0x0340000c
-----------------------------------------------------------------------------------------------------------
1ea20000 0c004003 dadf2200 00000104 b88300000d000000 80c04500 00000000 l .?...@.谶".....?.......?.....
00000000 00f80000 00000000 00000000 0000000000000000 00000000 00000000 l ...............................
00000000 00000000 00000000 00000000 0000000000000000 00000000 00000000 l ................................
00000000 00000000 00000000 00000000 0000000000000000 00000000 00000000 l ................................
<32 bytes per line>
此外可以通过print命令输出数据结构。
例如:
BBED> set dba 13,12
DBA 0x0340000c(54525964 13,12)
BBED> setoffset 0
OFFSET 0
BBED> p
BBED-00400: invalid blocktype (30)
此处报块不能被BBED查看。
如下即可:
BBED> set dba 13,3276
DBA 0x03400ccc(54529228 13,3276)
BBED> set offset 0
OFFSET 0
BBED> p
kcbh.type_kcbh
--------------
ub1 type_kcbh @0 0x06
可以通过指定名字来输出不可再分的数据结构如下,输出数据块头。
BBED> p kcbh
struct kcbh, 20 bytes @0
ub1 type_kcbh @0 0x06
ub1 frmt_kcbh @1 0xa2
ub1 spare1_kcbh @2 0x00
ub1 spare2_kcbh @3 0x00
ub4 rdba_kcbh @4 0x03400ccc
ub4 bas_kcbh @8 0x0024c46f
ub2 wrp_kcbh @12 0x0000
ub1 seq_kcbh @14 0x01
ub1 flg_kcbh @15 0x06 (KCBHFDLC,KCBHFCKV)
ub2 chkval_kcbh @16 0x2663
ub2 spare3_kcbh @18 0x0000
如果想确定块中的行数量,可以打印数据头接口或kdbh
BBED> p kdbh
struct kdbh, 14 bytes @100
ub1 kdbhflag @100 0x00 (NONE)
sb1kdbhntab @101 1
sb2 kdbhnrow @102 23
sb2 kdbhfrre @104 -1
sb2 kdbhfsbo @106 64
sb2 kdbhfseo @108 679
sb2 kdbhavsp @110 927
sb2 kdbhtosp @112 927
也可以指定数据结构的元素,如下:
BBED> p kdbhnrow
sb2 kdbhnrow @102 23
此外,可以通过kdbr数据结构来显示块的行信息,如下:
BBED> p kdbr
sb2 kdbr[0] @118 6864
sb2 kdbr[1] @120 7163
sb2 kdbr[2] @122 7465
sb2 kdbr[3] @124 7776
sb2 kdbr[4] @126 992
sb2 kdbr[5] @128 1293
sb2 kdbr[6] @130 1611
sb2 kdbr[7] @132 1924
sb2 kdbr[8] @134 2241
sb2 kdbr[9] @136 2544
sb2 kdbr[10] @138 2848
sb2 kdbr[11] @140 3160
sb2 kdbr[12] @142 3468
sb2 kdbr[13] @144 3775
sb2 kdbr[14] @146 4090
sb2 kdbr[15] @148 4395
sb2 kdbr[16] @150 679
sb2 kdbr[17] @152 5013
sb2 kdbr[18] @154 5324
sb2 kdbr[19] @156 5640
sb2 kdbr[20] @158 5943
sb2 kdbr[21] @160 6247
sb2 kdbr[22] @162 6565
然后打印行信息如下:
BBED> p *kdbr[0]
rowdata[6185]
-------------
ub1 rowdata[6185] @6964 0x2c
表示行从偏移8159开始。
DUMP一下看看:
BBED> d /v dba 13,3276 offset 6964 count 16
File: /oradata/tpcc1.dbf (13)
Block: 3276 Offsets: 6964 to6979 Dba:0x03400ccc
-----------------------------------------------------------------------------------------------------------
2c001102 c10204c3 05090402 c1140180 l,...?.?...?..
<32 bytes per line>