Oracle Study之案例--Oracle ASSM管理方式下的Bitmap
在基于此在LMT(Extent Local Management)下Oracle建议我们使用ASSM(Automatic Segment-Space Management),看看
Oracle doc是如何来解释ASSM的:
This keyword tells Oracle that you want to use bitmaps to manage the free space with in segments. A bitmap, in this case, is a map that describes the status of each data block within a segment with respect to the amount of space in the block available for inserting rows. As more or less space becomes available in a data block, its new state is reflected in the bitmap. Bitmaps enable Oracle to manage free space more automatically; thus, this form of space management is called automatic segment-space management. Locally managed tablespaces using automatic segment-space management can be created as smallfile (traditional) or bigfile tablespaces. AUTO is the default.
在Oracle 10g,在本地管理的表空间中,如果数据库块大小(db_block_size)为16KB或16KB以下,数据文件头保留64KB空间;若是32KB的块大小,则保留128KB。即数据块大小和文件头保留的数据块块数之间的对应关系为:
db_block_size=2 KB,文件头会保留32个数据块;
db_block_size=4 KB,文件头会保留16个数据块;
db_block_size=8 KB,文件头会保留8个数据块;
db_block_size=16 KB,文件头会保留4个数据块;
db_block_size=32 KB,文件头会保留4个数据块。
对于默认8KB块大小的表空间,Oracle保留8个块用于管理,其中数据块1和2用于记录数据文件头信息,数据块3~8用于记录区间的位图信息。
Oracle 11G:0号操作系统块,1-2是文件头,3-127是位图信息。128号开始及之后存放的是数据了―可能是段头或段的数据。
案例:
t2表是test2表空间的第一个segment:
11:24:30 SYS@ test1 >col owner for a10 11:24:43 SYS@ test1 >select OWNER,SEGMENT_NAME,TABLESPACE_NAME,FILE_ID,EXTENT_ID,BLOCK_ID,BLOCKS from dba_extents 2* where tablespace_name='TEST1' OWNER SEGMENT_NAME TABLESPACE_NAME FILE_ID EXTENT_ID BLOCK_ID BLOCKS ---------- -------------------- ------------------------------ ---------- ---------- ---------- ---------- SCOTT T2 TEST2 8 0 128 8 11:10:57 SYS@ test1 >alter system dump datafile 3 block min 1 block max 127; System altered.
DUMP文件(1#块为datafile header)
Start dump data blocks tsn: 22 file#:3 minblk 1 maxblk 127 Block 1 (file header) not dumped:use dump file header command Block dump from cache: Dump of buffer cache at level 4 for tsn=22, rdba=12582914 BH (0x227e9254) file#: 3 rdba: 0x00c00002 (3/2) class: 13 ba: 0x22516000 set: 3 pool 3 bsz: 8192 bsi: 0 sflg: 1 pwc: 0,0 dbwrid: 0 obj: -1 objn: 3 tsn: 22 afn: 3 hint: f hash: [0x2b7af910,0x2b7af910] lru: [0x227e93d4,0x227e9158] lru-flags: hot_buffer obj-flags: object_ckpt_list ckptq: [0x223e3ddc,0x2bbe3ba4] fileq: [0x223e3de4,0x2bbe3be0] objq: [0x27fa8800,0x223e4b0c] st: XCURRENT md: NULL tch: 0 flags: buffer_dirty redo_since_read LRBA: [0x34.188.0] LSCN: [0x0.a2349c] HSCN: [0x0.a2349c] HSUB: [1] cr pin refcnt: 0 sh pin refcnt: 0 Block dump from disk: buffer tsn: 22 rdba: 0x00c00002 (3/2) scn: 0x0000.0096c8a5 seq: 0x02 flg: 0x04 tail: 0xc8a51d02 frmt: 0x02 chkval: 0x72e8 type: 0x1d=KTFB Bitmapped File Space Header Hex dump of block: st=0, typ_found=1 Dump of memory from 0x00758200 to 0x0075A200 758200 0000A21D 00C00002 0096C8A5 04020000 [................] 758210 000072E8 00000003 00000008 00000500 [.r..............] 758220 00000001 00000000 00000000 0000007E [............~...] 758230 000004FF 00000000 00000090 0096C8A4 [................] 758240 00000000 00000000 00000000 00000000 [................] 758250 00000080 00000008 00000000 00000000 [................] 758260 00000000 00000000 00000000 00000000 [................] Repeat 504 times 75A1F0 00000000 00000000 00000000 C8A51D02 [................] File Space Header Block: Header Control: RelFno: 3, Unit: 8, Size: 1280, Flag: 1 AutoExtend: NO, Increment: 0, MaxSize: 0 Initial Area: 126, Tail: 1279, First: 0, Free: 144 Deallocation scn: 9881764.0 Header Opcode: Save: No Pending Op
block# 127:
Block dump from cache: Dump of buffer cache at level 4 for tsn=22, rdba=12583039 Block dump from disk: buffer tsn: 22 rdba: 0x00c0007f (3/127) scn: 0x0000.0090e601 seq: 0x01 flg: 0x04 tail: 0xe6011e01 frmt: 0x02 chkval: 0x4373 type: 0x1e=KTFB Bitmapped File Space Bitmap Hex dump of block: st=0, typ_found=1 Dump of memory from 0x00758200 to 0x0075A200 758200 0000A21E 00C0007F 0090E601 04010000 [................] 758210 00004373 00000003 03C10080 00000000 [sC..............] 758220 00000000 0000F800 00000000 00000000 [................] 758230 00000000 00000000 00000000 00000000 [................] Repeat 507 times 75A1F0 00000000 00000000 00000000 E6011E01 [................] File Space Bitmap Block: BitMap Control: RelFno: 3, BeginBlock: 62980224, Flag: 0, First: 0, Free: 63488 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000 0000000000000000
案例分析:
1、查看emp表存储信息
17:31:39 SYS@ test1 >col segment_name for a20 17:33:01 SYS@ test1 >select owner,segment_name,segment_type,tablespace_name,bytes/1024 from dba_segments 17:33:24 2 where segment_name='EMP'; OWNER SEGMENT_NAME SEGMENT_TYPE TABLESPACE_NAME BYTES/1024 ------------------------------ -------------------- ------------------ ------------------------------ ---------- SCOTT EMP TABLE USERS 64 17:31:06 SYS@ test1 >select tablespace_name,contents,extent_management,SEGMENT_SPACE_MANAGEMENT from dba_tablespaces; TABLESPACE_NAME CONTENTS EXTENT_MAN SEGMEN ------------------------------ --------- ---------- ------ SYSTEM PERMANENT DICTIONARY MANUAL USERS PERMANENT LOCAL AUTO 17:37:42 SYS@ test1 >COL OWNER FOR A10 17:37:54 SYS@ test1 >R 1 select owner,SEGMENT_NAME,EXTENT_ID, FILE_ID,BLOCK_ID,BLOCKS from dba_extents 2* where segment_name='EMP' OWNER SEGMENT_NAME EXTENT_ID FILE_ID BLOCK_ID BLOCKS ---------- -------------------------------------------------- ---------- ---------- ---------- ---------- SCOTT EMP 0 4 144 8 17:16:05 SYS@ test1 >select header_file,header_block,blocks,extents from dba_segments where segment_name='EMP'; HEADER_FILE HEADER_BLOCK BLOCKS EXTENTS ----------- ------------ ---------- ---------- 4 146 8 1
从以上可以看到,emp表存储在users表空间上,users表空间采用LMT管理;所以对于emp表,其segment space采用auto方式。起始block为144,segment header block为146.
2、对emp表中的block进行dump分析
17:39:30 SYS@ test1 >alter system dump datafile 4 block min 144 block max 151;
System altered.
查看dump的trace文件:
[oracle@RH6 ~]$ ls -lt /u01/app/oracle/diag/rdbms/test1/test1/trace/|more
total 56908
-rw-r----- 1 oracle oinstall 25923 Dec 15 17:42 test1_ora_2385.trc
[oracle@RH6 ~]$ more /u01/app/oracle/diag/rdbms/test1/test1/trace/test1_ora_2385.trc
Trace file /u01/app/oracle/diag/rdbms/test1/test1/trace/test1_ora_2385.trc Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production With the Partitioning, OLAP, Data Mining and Real Application Testing options ORACLE_HOME = /u01/app/oracle/product/11.2.0/db_1 System name: Linux Node name: rh6.cuug.net Release: 2.6.32-71.el6.i686 Version: #1 SMP Wed Sep 1 01:26:34 EDT 2010 Machine: i686 Instance name: test1 Redo thread mounted by this instance: 1 Oracle process number: 0 Unix process pid: 2385, image: [email protected] *** 2014-04-22 10:33:45.255 Breaking the connection before proto/dty negotiation, error raised 3113 Trace file /u01/app/oracle/diag/rdbms/test1/test1/trace/test1_ora_2385.trc Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production With the Partitioning, OLAP, Data Mining and Real Application Testing options ORACLE_HOME = /u01/app/oracle/product/11.2.0/db_1 System name: Linux Node name: RH6.cuug.net Release: 2.6.32-71.el6.i686 Version: #1 SMP Wed Sep 1 01:26:34 EDT 2010 Machine: i686 Instance name: test1 Redo thread mounted by this instance: 1 Oracle process number: 17 Unix process pid: 2385, image: [email protected] (TNS V1-V3) *** 2014-12-15 17:35:47.781 *** SESSION ID:(1.5) 2014-12-15 17:35:47.781 *** CLIENT ID:() 2014-12-15 17:35:47.781 *** SERVICE NAME:() 2014-12-15 17:35:47.781 *** MODULE NAME:([email protected] (TNS V1-V3)) 2014-12-15 17:35:47.781 *** ACTION NAME:() 2014-12-15 17:35:47.781 Thread 1 checkpoint: logseq 41, block 2, scn 10122512 cache-low rba: logseq 41, block 7060 on-disk rba: logseq 41, block 7085, scn 10126253 change track rba: logseq 41, block 7085, scn 10126337 start recovery at logseq 41, block 7060, scn 0 *** 2014-12-15 17:35:47.995 Started writing zeroblks thread 1 seq 41 blocks 7085-7092 *** 2014-12-15 17:35:48.030 Completed writing zeroblks thread 1 seq 41 ==== Redo read statistics for thread 1 ==== Total physical reads (from disk and memory): 4096Kb -- Redo read_disk statistics -- Read rate (ASYNC): 12Kb in 0.25s => 0.05 Mb/sec Longest record: 1Kb, moves: 0/41 (0%) Change moves: 1/11 (9%), moved: 0Mb Longest LWN: 9Kb, moves: 0/3 (0%), moved: 0Mb Last redo scn: 0x0000.009a83ac (10126252) ---------------------------------------------- ----- Recovery Hash Table Statistics --------- Hash table buckets = 32768 Longest hash chain = 1 Average hash chain = 25/25 = 1.0 Max compares per lookup = 1 Avg compares per lookup = 30/67 = 0.4 ---------------------------------------------- *** 2014-12-15 17:35:48.085 KCRA: start recovery claims for 25 data blocks *** 2014-12-15 17:35:48.256 KCRA: blocks processed = 25/25, claimed = 25, eliminated = 0 *** 2014-12-15 17:35:48.257 Recovery of Online Redo Log: Thread 1 Group 4 Seq 41 Reading mem 0 *** 2014-12-15 17:35:48.382 Completed redo application of 0.01MB *** 2014-12-15 17:35:50.522 Completed recovery checkpoint IR RIA: redo_size 12288 bytes, time_taken 267 ms ----- Recovery Hash Table Statistics --------- Hash table buckets = 32768 Longest hash chain = 1 Average hash chain = 25/25 = 1.0 Max compares per lookup = 1 Avg compares per lookup = 47/55 = 0.9 ---------------------------------------------- Recovery sets nab of thread 1 seq 41 to 7085 with 8 zeroblks *** 2014-12-15 17:36:09.120 kwqmnich: current time:: 9: 36: 8: 0 kwqmnich: instance no 0 repartition flag 1 kwqmnich: initialized job cache structure kwqinfy: Call kwqrNondurSubInstTsk *** 2014-12-15 17:42:08.722 Start dump data blocks tsn: 4 file#:4 minblk 144 maxblk 151 Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777360
Block dump from disk:
buffer tsn: 4 rdba: 0x01000090 (4/144)
scn: 0x0000.0096c992 seq: 0x02 flg: 0x04 tail: 0xc9922002
frmt: 0x02 chkval: 0x4bc8 type: 0x20=FIRST LEVEL BITMAP BLOCK
其中在第144个block的dump信息中我们发现type: 0x20=FIRST LEVEL BITMAP BLOCK,说明这个block是第一级bitmap block,Oracle用第一级bitmap block来管理data block的使用情况:
Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A220 01000090 0096C992 04020000 [ ...............] 8E8210 00004BC8 00000000 00000000 00000000 [.K..............] 8E8220 00000000 00000000 00000000 00000000 [................] Repeat 1 times 8E8240 00000000 00000000 00000000 00000004 [................] 8E8250 FFFFFFFF 00000000 00000003 00000008 [................] 8E8260 00010001 00000000 00000000 00000000 [................] 8E8270 00000005 00000003 54682010 54682010 [......... hT. hT] 8E8280 00000000 00000000 00000000 00000000 [................] 8E8290 01000091 00000000 00000000 00000008 [................] 8E82A0 00000008 01000098 00000000 00000000 [................] 8E82B0 00000000 00000005 00000000 00000001 [................] 8E82C0 000044A3 0096C903 00000000 01000090 [.D..............] 8E82D0 00000008 00000000 00000000 00000000 [................] 8E82E0 00000000 00000000 00000000 00000000 [................] Repeat 9 times 8E8380 00000000 00000000 00000000 55551511 [..............UU] 8E8390 00000000 00000000 00000000 00000000 [................] Repeat 485 times 8EA1F0 00000000 00000000 00000000 C9922002 [............. ..] Dump of First Level Bitmap Block -------------------------------- nbits : 4 nranges: 1 parent dba: 0x01000091 poffset: 0 unformatted: 0 total: 8 first useful block: 3 owning instance : 1 instance ownership changed at 11/16/2014 11:54:56 Last successful Search 11/16/2014 11:54:56 Freeness Status: nf1 0 nf2 0 nf3 0 nf4 5 Extent Map Block Offset: 4294967295 First free datablock : 3 Bitmap block lock opcode 0 Locker xid: : 0x0000.000.00000000 Inc #: 0 Objd: 17571 HWM Flag: HWM Set Highwater:: 0x01000098 ext#: 0 blk#: 8 ext size: 8 #blocks in seg. hdr's freelists: 0 #blocks below: 5 mapblk 0x00000000 offset: 0 -------------------------------------------------------- DBA Ranges : -------------------------------------------------------- 0x01000090 Length: 8 Offset: 0 0:Metadata 1:Metadata 2:Metadata 3:75-100% free 4:75-100% free 5:75-100% free 6:75-100% free 7:75-100% free -------------------------------------------------------- Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777361
Block dump from disk:
buffer tsn: 4 rdba: 0x01000091 (4/145)
scn: 0x0000.0096c97a seq: 0x02 flg: 0x04 tail: 0xc97a2102
frmt: 0x02 chkval: 0xc282 type: 0x21=SECOND LEVEL BITMAP BLOCK
145#block的类型是:type: 0x21=SECOND LEVEL BITMAP BLOCK,说明该block是二级bitmap block,他是用来管理一级bitmap block的。
Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A221 01000091 0096C97A 04020000 [!.......z.......] 8E8210 0000C282 00000000 00000000 00000000 [................] 8E8220 00000000 00000000 00000000 00000000 [................] Repeat 1 times 8E8240 00000000 00000000 00000000 01000092 [................] 8E8250 00000001 00000001 00000000 00000000 [................] 8E8260 00000000 00000000 000044A3 00000001 [.........D......] 8E8270 00000000 01000090 00010005 00000000 [................] 8E8280 00000000 00000000 00000000 00000000 [................] Repeat 502 times 8EA1F0 00000000 00000000 00000000 C97A2102 [.............!z.] Dump of Second Level Bitmap Block number: 1 nfree: 1 ffree: 0 pdba: 0x01000092 Inc #: 0 Objd: 17571 opcode:0 xid: L1 Ranges : -------------------------------------------------------- 0x01000090 Free: 5 Inst: 1 -------------------------------------------------------- Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777362 BH (0x23bfb924) file#: 4 rdba: 0x01000092 (4/146) class: 4 ba: 0x23bde000 set: 2 pool 2 bsz: 8192 bsi: 0 sflg: 0 pwc: 0,0 dbwrid: 0 obj: 17571 objn: -1 tsn: 4 afn: 4 hint: f hash: [0x23bfba74,0x2b7af538] lru: [0x23bfbaa4,0x2bbdd3b4] ckptq: [NULL] fileq: [NULL] objq: [NULL] st: CR md: NULL tch: 1 cr: [scn: 0x0.9ad2c6],[xid: 0x0.0.0],[uba: 0x0.0.0],[cls: 0x0.9ad2c6],[sfl: 0x0],[lc: 0x0.0] flags: cr pin refcnt: 0 sh pin refcnt: 0 BH (0x23bfb9f8) file#: 4 rdba: 0x01000092 (4/146) class: 4 ba: 0x23be0000 set: 2 pool 2 bsz: 8192 bsi: 0 sflg: 0 pwc: 0,0 dbwrid: 0 obj: 17571 objn: -1 tsn: 4 afn: 4 hint: f hash: [0x2b7af538,0x23bfb9a0] lru: [0x2bbdd3b4,0x23bfb9d0] ckptq: [NULL] fileq: [NULL] objq: [NULL] st: CR md: NULL tch: 1 cr: [scn: 0x0.9ad2c1],[xid: 0x0.0.0],[uba: 0x0.0.0],[cls: 0x0.9ad2c1],[sfl: 0x0],[lc: 0x0.0] flags: cr pin refcnt: 0 sh pin refcnt: 0
Block dump from disk:
buffer tsn: 4 rdba: 0x01000092 (4/146)
scn: 0x0000.0096c992 seq: 0x03 flg: 0x04 tail: 0xc9922303
frmt: 0x02 chkval: 0xefbe type: 0x23=PAGETABLE SEGMENT HEADER
接下来简单看看146#block的类型是:
type: 0x23=PAGETABLE SEGMENT HEADER
也就是我们熟悉的segment header block,这里它也同时是一个特殊的三级bitmap block
同时最下面一条非常有用的信息是:
Second Level Bitmap block DBAs
--------------------------------------------------------
DBA 1: 0x01000091
记录了二级btimap block的地址,因为segment小,只有1个二级bitmap block,大家也可以创建一个大一
点的表,主要需要保证要有足够多的block才可能看到第二个二级block出现,要看到出现一个三级bitmap
block可能非常的难。
Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A223 01000092 0096C992 04030000 [#...............] 8E8210 0000EFBE 00000000 00000000 00000000 [................] 8E8220 00000000 00000001 00000008 00000A9C [................] 8E8230 00000000 00000008 00000008 01000098 [................] 8E8240 00000000 00000000 00000000 00000005 [................] 8E8250 00000000 00000000 00000000 00000000 [................] 8E8260 00000008 00000008 01000098 00000000 [................] 8E8270 00000000 00000000 00000005 01000090 [................] 8E8280 01000090 00000000 00000000 00000000 [................] 8E8290 00000000 00000000 00000000 00000000 [................] Repeat 3 times 8E82D0 00000001 00002000 00000000 00001434 [..... ......4...] 8E82E0 00000000 01000091 00000001 01000090 [................] 8E82F0 01000091 00000000 00000000 00000000 [................] 8E8300 00000000 00000000 00000001 00000000 [................] 8E8310 000044A3 10000000 01000090 00000008 [.D..............] 8E8320 00000000 00000000 00000000 00000000 [................] Repeat 152 times 8E8CB0 01000090 01000093 00000000 00000000 [................] 8E8CC0 00000000 00000000 00000000 00000000 [................] Repeat 151 times 8E9640 00000000 00000000 01000091 00000000 [................] 8E9650 00000000 00000000 00000000 00000000 [................] Repeat 185 times 8EA1F0 00000000 00000000 00000000 C9922303 [.............#..] Extent Control Header ----------------------------------------------------------------- Extent Header:: spare1: 0 spare2: 0 #extents: 1 #blocks: 8 last map 0x00000000 #maps: 0 offset: 2716 Highwater:: 0x01000098 ext#: 0 blk#: 8 ext size: 8 #blocks in seg. hdr's freelists: 0 #blocks below: 5 mapblk 0x00000000 offset: 0 Unlocked -------------------------------------------------------- Low HighWater Mark : Highwater:: 0x01000098 ext#: 0 blk#: 8 ext size: 8 #blocks in seg. hdr's freelists: 0 #blocks below: 5 mapblk 0x00000000 offset: 0 Level 1 BMB for High HWM block: 0x01000090 Level 1 BMB for Low HWM block: 0x01000090 -------------------------------------------------------- Segment Type: 1 nl2: 1 blksz: 8192 fbsz: 0 L2 Array start offset: 0x00001434 First Level 3 BMB: 0x00000000 L2 Hint for inserts: 0x01000091 Last Level 1 BMB: 0x01000090 Last Level II BMB: 0x01000091 Last Level III BMB: 0x00000000 Map Header:: next 0x00000000 #extents: 1 obj#: 17571 flag: 0x10000000 Inc # 0 Extent Map ----------------------------------------------------------------- 0x01000090 length: 8 Auxillary Map -------------------------------------------------------- Extent 0 : L1 dba: 0x01000090 Data dba: 0x01000093 -------------------------------------------------------- Second Level Bitmap block DBAs -------------------------------------------------------- DBA 1: 0x01000091 Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777363 Block dump from disk: buffer tsn: 4 rdba: 0x01000093 (4/147) scn: 0x0000.0096c992 seq: 0x02 flg: 0x04 tail: 0xc9920602 frmt: 0x02 chkval: 0xcd6c type: 0x06=trans data Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A206 01000093 0096C992 04020000 [................] 8E8210 0000CD6C 00000001 000044A3 0096C992 [l........D......] 8E8220 00000000 00320002 01000090 00000000 [......2.........] 8E8230 00000000 00000000 00000000 00000000 [................] Repeat 2 times 8E8260 00000000 00000000 000EFFFF 1F8A1F98 [................] 8E8270 00001F8A 00000000 00000000 00000000 [................] 8E8280 00000000 00000000 00000000 00000000 [................] Repeat 502 times 8EA1F0 00000000 00000000 00000000 C9920602 [................] Block header dump: 0x01000093 Object id on Block? Y seg/obj: 0x44a3 csc: 0x00.96c992 itc: 2 flg: E typ: 1 - DATA brn: 0 bdba: 0x1000090 ver: 0x01 opc: 0 inc: 0 exflg: 0 Itl Xid Uba Flag Lck Scn/Fsc 0x01 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 --11G默认用快速提交,Flag是U,正常提交是C。 --Itl: ITL事务槽号的流水编号 --Xid:transac[X]tion identified(事务ID),由und的段号+undo的槽号+undo槽号的覆盖次数三部分组成 --Uba:undo block address记录了最近一次的该记录的前镜像(修改前的值) --Flag:C是提交,U是快速提交,---是未提交(Flg C=Committed U=Commit Upper Bound T=Active at CSC) --Lck:锁住了几行数据,对应有几个行锁 --Scn/Fsc:Scn=SCN of commited TX; Fsc=Free space credit(bytes) --SCN WRAP:如果事务已提交并完成清洗,该字段保存事务提交SCN的SCN WRAP部分,否则该字段保存空闲预支字节数(FSC).比如删除了一行数据10个字节,在事务提前前,这10个字节就属于fsc(即会写到SCN WRAP),只有事务提交后,才能正式返回到空闲空间。 bdba: 0x01000093 data_block_dump,data header at 0x8e8264 =============== tsiz: 0x1f98 hsiz: 0xe pbl: 0x008e8264 76543210 flag=-------- ntab=0 nrow=0 frre=-1 fsbo=0xe fseo=0x1f98 avsp=0x1f8a tosp=0x1f8a block_row_dump: end_of_block_dump Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777364 Block dump from disk: buffer tsn: 4 rdba: 0x01000094 (4/148) scn: 0x0000.0096c992 seq: 0x02 flg: 0x04 tail: 0xc9920602 frmt: 0x02 chkval: 0xcd6b type: 0x06=trans data Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A206 01000094 0096C992 04020000 [................] 8E8210 0000CD6B 00000001 000044A3 0096C992 [k........D......] 8E8220 00000000 00320002 01000090 00000000 [......2.........] 8E8230 00000000 00000000 00000000 00000000 [................] Repeat 2 times 8E8260 00000000 00000000 000EFFFF 1F8A1F98 [................] 8E8270 00001F8A 00000000 00000000 00000000 [................] 8E8280 00000000 00000000 00000000 00000000 [................] Repeat 502 times 8EA1F0 00000000 00000000 00000000 C9920602 [................] Block header dump: 0x01000094 Object id on Block? Y seg/obj: 0x44a3 csc: 0x00.96c992 itc: 2 flg: E typ: 1 - DATA brn: 0 bdba: 0x1000090 ver: 0x01 opc: 0 inc: 0 exflg: 0 Itl Xid Uba Flag Lck Scn/Fsc 0x01 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 bdba: 0x01000094 data_block_dump,data header at 0x8e8264 =============== tsiz: 0x1f98 hsiz: 0xe pbl: 0x008e8264 76543210 flag=-------- ntab=0 nrow=0 frre=-1 fsbo=0xe fseo=0x1f98 avsp=0x1f8a tosp=0x1f8a block_row_dump: end_of_block_dump Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777365 Block dump from disk: buffer tsn: 4 rdba: 0x01000095 (4/149) scn: 0x0000.009722f6 seq: 0x01 flg: 0x04 tail: 0x22f60601 frmt: 0x02 chkval: 0x52a5 type: 0x06=trans data Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A206 01000095 009722F6 04010000 [........."......] 8E8210 000052A5 00000001 000044A3 009722F6 [.R.......D..."..] 8E8220 00000000 00320002 01000090 001F001B [......2.........] 8E8230 0000007A 01C01C55 00230121 0000A000 [z...U...!.#.....] 8E8240 00971D50 00000000 00000000 00000000 [P...............] 8E8250 00000000 00000000 00000000 00000000 [................] 8E8260 00000000 000E0100 002EFFFF 1D331D61 [............a.3.] 8E8270 00001D33 1F72000E 1F1C1F47 1EC61EF3 [3.....r.G.......] 8E8280 1E741E9D 1E261E4C 1DD51DFB 1D881DAF [..t.L.&.........] 8E8290 00001D61 00000000 00000000 00000000 [a...............] 8E82A0 00000000 00000000 00000000 00000000 [................] Repeat 465 times 8E9FC0 00000000 08002C00 2350C203 4C494D06 [.....,....P#.MIL] 8E9FD0 0552454C 52454C43 4EC2034B B6770753 [LER.CLERK..NS.w.] 8E9FE0 01011701 0EC20201 0BC102FF 0308002C [............,...] 8E9FF0 040350C2 44524F46 414E4107 5453594C [.P..FORD.ANALYST] 8EA000 434CC203 0CB57707 01010103 FF1FC202 [..LC.w..........] 8EA010 2C15C102 C2020800 414A0550 0553454D [...,....P.JAMES.] 8EA020 52454C43 4DC2034B B5770763 0101030C [CLERK..Mc.w.....] 8EA030 0AC20301 C102FF33 08002C1F 4D4FC203 [....3....,....OM] 8EA040 41444105 4305534D 4B52454C 594EC203 [.ADAMS.CLERK..NY] 8EA050 05BB7707 01010117 FF0CC202 2C15C102 [.w.............,] 8EA060 C2030800 54062D4F 454E5255 41530852 [....O-.TURNER.SA] 8EA070 4D53454C C2034E41 7707634D 010809B5 [LESMAN..Mc.w....] 8EA080 C2020101 02800110 002C1FC1 4FC20308 [..........,....O] 8EA090 494B0428 5009474E 49534552 544E4544 [(.KING.PRESIDENT] 8EA0A0 B57707FF 0101110B 33C20201 0BC102FF [..w........3....] 8EA0B0 0308002C 05594EC2 544F4353 4E410754 [,....NY.SCOTT.AN] 8EA0C0 53594C41 4CC20354 BB770743 01011304 [ALYST..LC.w.....] 8EA0D0 1FC20201 15C102FF 0308002C 05534EC2 [........,....NS.] 8EA0E0 52414C43 414D074B 4547414E 4FC20352 [CLARK.MANAGER..O] 8EA0F0 B5770728 01010906 19C20301 C102FF33 [(.w.........3...] 8EA100 08002C0B 634DC203 414C4205 4D07454B [.,....Mc.BLAKE.M] 8EA110 47414E41 C2035245 7707284F 010105B5 [ANAGER..O(.w....] 8EA120 C2030101 02FF331D 002C1FC1 4DC20308 [.....3....,....M] 8EA130 414D0637 4E495452 4C415308 414D5345 [7.MARTIN.SALESMA] 8EA140 4DC2034E B5770763 01011C09 0DC20301 [N..Mc.w.........] 8EA150 0FC20233 2C1FC102 C2030800 4A05434C [3......,....LC.J] 8EA160 53454E4F 4E414D07 52454741 284FC203 [ONES.MANAGER..O(] 8EA170 04B57707 01010102 4C1EC203 15C102FF [.w.........L....] 8EA180 0308002C 04164CC2 44524157 4C415308 [,....L..WARD.SAL] 8EA190 414D5345 4DC2034E B5770763 01011602 [ESMAN..Mc.w.....] 8EA1A0 0DC20301 06C20233 2C1FC102 C2030800 [....3......,....] 8EA1B0 4105644B 4E454C4C 4C415308 414D5345 [Kd.ALLEN.SALESMA] 8EA1C0 4DC2034E B5770763 01011402 11C20201 [N..Mc.w.........] 8EA1D0 0204C202 002C1FC1 4AC20308 4D530546 [......,....JF.SM] 8EA1E0 05485449 52454C43 50C2034B B4770703 [ITH.CLERK..P..w.] 8EA1F0 0101110C 09C20201 15C102FF 22F60601 [..............."] Block header dump: 0x01000095 Object id on Block? Y seg/obj: 0x44a3 csc: 0x00.9722f6 itc: 2 flg: E typ: 1 - DATA brn: 0 bdba: 0x1000090 ver: 0x01 opc: 0 inc: 0 exflg: 0 Itl Xid Uba Flag Lck Scn/Fsc 0x01 0x001b.01f.0000007a 0x01c01c55.0121.23 C-U- 0 scn 0x0000.00971d50 0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 bdba: 0x01000095 data_block_dump,data header at 0x8e8264 =============== tsiz: 0x1f98 hsiz: 0x2e pbl: 0x008e8264 76543210 flag=-------- ntab=1 nrow=14 frre=-1 fsbo=0x2e fseo=0x1d61 avsp=0x1d33 tosp=0x1d33 0xe:pti[0] nrow=14 offs=0 0x12:pri[0] offs=0x1f72 0x14:pri[1] offs=0x1f47 0x16:pri[2] offs=0x1f1c 0x18:pri[3] offs=0x1ef3 0x1a:pri[4] offs=0x1ec6 0x1c:pri[5] offs=0x1e9d 0x1e:pri[6] offs=0x1e74 0x20:pri[7] offs=0x1e4c 0x22:pri[8] offs=0x1e26 0x24:pri[9] offs=0x1dfb 0x26:pri[10] offs=0x1dd5 0x28:pri[11] offs=0x1daf 0x2a:pri[12] offs=0x1d88 0x2c:pri[13] offs=0x1d61 block_row_dump: tab 0, row 0, @0x1f72 tl: 38 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4a 46 col 1: [ 5] 53 4d 49 54 48 col 2: [ 5] 43 4c 45 52 4b col 3: [ 3] c2 50 03 col 4: [ 7] 77 b4 0c 11 01 01 01 col 5: [ 2] c2 09 col 6: *NULL* col 7: [ 2] c1 15 tab 0, row 1, @0x1f47 tl: 43 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4b 64 col 1: [ 5] 41 4c 4c 45 4e col 2: [ 8] 53 41 4c 45 53 4d 41 4e col 3: [ 3] c2 4d 63 col 4: [ 7] 77 b5 02 14 01 01 01 col 5: [ 2] c2 11 col 6: [ 2] c2 04 col 7: [ 2] c1 1f tab 0, row 2, @0x1f1c tl: 43 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4c 16 col 1: [ 4] 57 41 52 44 col 2: [ 8] 53 41 4c 45 53 4d 41 4e col 3: [ 3] c2 4d 63 col 4: [ 7] 77 b5 02 16 01 01 01 col 5: [ 3] c2 0d 33 col 6: [ 2] c2 06 col 7: [ 2] c1 1f tab 0, row 3, @0x1ef3 tl: 41 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4c 43 col 1: [ 5] 4a 4f 4e 45 53 col 2: [ 7] 4d 41 4e 41 47 45 52 col 3: [ 3] c2 4f 28 col 4: [ 7] 77 b5 04 02 01 01 01 col 5: [ 3] c2 1e 4c col 6: *NULL* col 7: [ 2] c1 15 tab 0, row 4, @0x1ec6 tl: 45 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4d 37 col 1: [ 6] 4d 41 52 54 49 4e col 2: [ 8] 53 41 4c 45 53 4d 41 4e col 3: [ 3] c2 4d 63 col 4: [ 7] 77 b5 09 1c 01 01 01 col 5: [ 3] c2 0d 33 col 6: [ 2] c2 0f col 7: [ 2] c1 1f tab 0, row 5, @0x1e9d tl: 41 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4d 63 col 1: [ 5] 42 4c 41 4b 45 col 2: [ 7] 4d 41 4e 41 47 45 52 col 3: [ 3] c2 4f 28 col 4: [ 7] 77 b5 05 01 01 01 01 col 5: [ 3] c2 1d 33 col 6: *NULL* col 7: [ 2] c1 1f tab 0, row 6, @0x1e74 tl: 41 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4e 53 col 1: [ 5] 43 4c 41 52 4b col 2: [ 7] 4d 41 4e 41 47 45 52 col 3: [ 3] c2 4f 28 col 4: [ 7] 77 b5 06 09 01 01 01 col 5: [ 3] c2 19 33 col 6: *NULL* col 7: [ 2] c1 0b tab 0, row 7, @0x1e4c tl: 40 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4e 59 col 1: [ 5] 53 43 4f 54 54 col 2: [ 7] 41 4e 41 4c 59 53 54 col 3: [ 3] c2 4c 43 col 4: [ 7] 77 bb 04 13 01 01 01 col 5: [ 2] c2 1f col 6: *NULL* col 7: [ 2] c1 15 tab 0, row 8, @0x1e26 tl: 38 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4f 28 col 1: [ 4] 4b 49 4e 47 col 2: [ 9] 50 52 45 53 49 44 45 4e 54 col 3: *NULL* col 4: [ 7] 77 b5 0b 11 01 01 01 col 5: [ 2] c2 33 col 6: *NULL* col 7: [ 2] c1 0b tab 0, row 9, @0x1dfb tl: 43 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4f 2d col 1: [ 6] 54 55 52 4e 45 52 col 2: [ 8] 53 41 4c 45 53 4d 41 4e col 3: [ 3] c2 4d 63 col 4: [ 7] 77 b5 09 08 01 01 01 col 5: [ 2] c2 10 col 6: [ 1] 80 col 7: [ 2] c1 1f tab 0, row 10, @0x1dd5 tl: 38 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 4f 4d col 1: [ 5] 41 44 41 4d 53 col 2: [ 5] 43 4c 45 52 4b col 3: [ 3] c2 4e 59 col 4: [ 7] 77 bb 05 17 01 01 01 col 5: [ 2] c2 0c col 6: *NULL* col 7: [ 2] c1 15 tab 0, row 11, @0x1daf tl: 38 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 2] c2 50 col 1: [ 5] 4a 41 4d 45 53 col 2: [ 5] 43 4c 45 52 4b col 3: [ 3] c2 4d 63 col 4: [ 7] 77 b5 0c 03 01 01 01 col 5: [ 3] c2 0a 33 col 6: *NULL* col 7: [ 2] c1 1f tab 0, row 12, @0x1d88 tl: 39 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 50 03 col 1: [ 4] 46 4f 52 44 col 2: [ 7] 41 4e 41 4c 59 53 54 col 3: [ 3] c2 4c 43 col 4: [ 7] 77 b5 0c 03 01 01 01 col 5: [ 2] c2 1f col 6: *NULL* col 7: [ 2] c1 15 tab 0, row 13, @0x1d61 tl: 39 fb: --H-FL-- lb: 0x0 cc: 8 col 0: [ 3] c2 50 23 col 1: [ 6] 4d 49 4c 4c 45 52 col 2: [ 5] 43 4c 45 52 4b col 3: [ 3] c2 4e 53 col 4: [ 7] 77 b6 01 17 01 01 01 col 5: [ 2] c2 0e col 6: *NULL* col 7: [ 2] c1 0b end_of_block_dump Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777366 Block dump from disk: buffer tsn: 4 rdba: 0x01000096 (4/150) scn: 0x0000.0096c992 seq: 0x02 flg: 0x04 tail: 0xc9920602 frmt: 0x02 chkval: 0xcd69 type: 0x06=trans data Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A206 01000096 0096C992 04020000 [................] 8E8210 0000CD69 00000001 000044A3 0096C992 [i........D......] 8E8220 00000000 00320002 01000090 00000000 [......2.........] 8E8230 00000000 00000000 00000000 00000000 [................] Repeat 2 times 8E8260 00000000 00000000 000EFFFF 1F8A1F98 [................] 8E8270 00001F8A 00000000 00000000 00000000 [................] 8E8280 00000000 00000000 00000000 00000000 [................] Repeat 502 times 8EA1F0 00000000 00000000 00000000 C9920602 [................] Block header dump: 0x01000096 Object id on Block? Y seg/obj: 0x44a3 csc: 0x00.96c992 itc: 2 flg: E typ: 1 - DATA brn: 0 bdba: 0x1000090 ver: 0x01 opc: 0 inc: 0 exflg: 0 Itl Xid Uba Flag Lck Scn/Fsc 0x01 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 bdba: 0x01000096 data_block_dump,data header at 0x8e8264 =============== tsiz: 0x1f98 hsiz: 0xe pbl: 0x008e8264 76543210 flag=-------- ntab=0 nrow=0 frre=-1 fsbo=0xe fseo=0x1f98 avsp=0x1f8a tosp=0x1f8a block_row_dump: end_of_block_dump Block dump from cache: Dump of buffer cache at level 4 for tsn=4, rdba=16777367 Block dump from disk: buffer tsn: 4 rdba: 0x01000097 (4/151) scn: 0x0000.0096c992 seq: 0x02 flg: 0x04 tail: 0xc9920602 frmt: 0x02 chkval: 0xcd68 type: 0x06=trans data Hex dump of block: st=0, typ_found=1 Dump of memory from 0x008E8200 to 0x008EA200 8E8200 0000A206 01000097 0096C992 04020000 [................] 8E8210 0000CD68 00000001 000044A3 0096C992 [h........D......] 8E8220 00000000 00320002 01000090 00000000 [......2.........] 8E8230 00000000 00000000 00000000 00000000 [................] Repeat 2 times 8E8260 00000000 00000000 000EFFFF 1F8A1F98 [................] 8E8270 00001F8A 00000000 00000000 00000000 [................] 8E8280 00000000 00000000 00000000 00000000 [................] Repeat 502 times 8EA1F0 00000000 00000000 00000000 C9920602 [................] Block header dump: 0x01000097 Object id on Block? Y seg/obj: 0x44a3 csc: 0x00.96c992 itc: 2 flg: E typ: 1 - DATA brn: 0 bdba: 0x1000090 ver: 0x01 opc: 0 inc: 0 exflg: 0 Itl Xid Uba Flag Lck Scn/Fsc 0x01 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 bdba: 0x01000097 data_block_dump,data header at 0x8e8264 =============== tsiz: 0x1f98 hsiz: 0xe pbl: 0x008e8264 76543210 flag=-------- ntab=0 nrow=0 frre=-1 fsbo=0xe fseo=0x1f98 avsp=0x1f8a tosp=0x1f8a block_row_dump: end_of_block_dump End dump data blocks tsn: 4 file#: 4 minblk 144 maxblk 151
查看emp表存储记录的block:
11:14:36 SYS@ test1 >conn scott/tiger Connected. 11:14:39 SCOTT@ test1 >select rowid,ename from emp where rownum=1; ROWID ENAME ------------------ ---------- AAAESjAAEAAAACVAAA SMITH 11:15:05 SCOTT@ test1 >select dbms_rowid.ROWID_RELATIVE_FNO(rowid) ,dbms_rowid.ROWID_BLOCK_NUMBER(rowid) from emp where rownum=1; DBMS_ROWID.ROWID_RELATIVE_FNO(ROWID) DBMS_ROWID.ROWID_BLOCK_NUMBER(ROWID) ------------------------------------ ------------------------------------ 4 149
从以上dump可以看到,第149#块开始用于存储数据(144-148用于segment header)