您好,登錄后才能下訂單哦!
Oracle Study之案例--Oracle 數(shù)據(jù)塊地址(Block Address)
Oracle訪問數(shù)據(jù)是以block為單位,本文簡單介紹了如何通過Block Address在內(nèi)存中獲取所需要的block。
DBA(data block address):
A DBA is the address of an oracle data block for access purposes.
RDBA (Tablespace relative database block address):
RDBA 是相對數(shù)據(jù)塊地址,是數(shù)據(jù)所在的地址,rdba可就是rowid 中rfile#+block#
ROWID:
Oracle在通過Index訪問時,通過rowid確定row的位置;我們都知道rowid表示一行的物理地址,一行唯一確定一個rowid,并且在使用中一般不會改變,除非rowid之后在行的物理位置發(fā)生改變的情況下才會發(fā)生變化。需要注意的是rowid并不會真正存在于表的data block中,但是他會存在于index當(dāng)中,用來通過rowid來尋找表中的行數(shù)據(jù)。
Oracle8以前一個rowid占用6個字節(jié)大小的存儲空間(10bit file#+22bit block#+16bit row#),那么oracle 8以后這個rowid的存儲空間擴(kuò)大到了10個字節(jié)(32bit object#+10bit rfile#+22bit block#+16bit row#),所以數(shù)據(jù)庫中數(shù)據(jù)庫文件個數(shù)的限制從整個數(shù)據(jù)庫最多只能有的2^10-1個數(shù)據(jù)文件,變?yōu)榱嗣總€表空間中可以最多有2^10-1個數(shù)據(jù)文件。
(需要注意的是:local index中存儲的rowid是6個字節(jié),而global index中存儲的rowid是10個字節(jié))
那么增加的32bit object#這個前綴主要就是用來定位表空間的,同時這個object#其實對應(yīng)的就是data_object_id,由于一個段對象只能屬于一個表空間,同時data_object_id就是標(biāo)識了一個段的物理存儲id.因此object#+rfile#就可以唯一定位當(dāng)前的rowid是在那個數(shù)據(jù)文件上了。
我們可以通過dbms_rowid這個包來轉(zhuǎn)換我們的rowid成不同組成部分:
dbms_rowid.rowid_object(rowid) ---> 32bit object#dbms_rowid.rowid_relative_fno(rowid) ---> 10bit rfile#dbms_rowid.rowid_block_number(rowid) ---> 22bit block#dbms_rowid.rowid_row_number(rowid) ---> 16bit row#
案例分析:
1、通過dbms_utility轉(zhuǎn)換地址
10:33:59 SYS@ test1 >desc dbms_utility FUNCTION DATA_BLOCK_ADDRESS_BLOCK RETURNS NUMBER Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- DBA NUMBER IN FUNCTION DATA_BLOCK_ADDRESS_FILE RETURNS NUMBER Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- DBA NUMBER IN FUNCTION MAKE_DATA_BLOCK_ADDRESS RETURNS NUMBER Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- FILE NUMBER IN BLOCK NUMBER IN
2、通過rowid獲取RDBA
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
3、通過Dump獲取block信息
11:42:16 SYS@ test1 >alter system dump datafile 4 block 149;
System altered.
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
[........."......]
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
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
4、通過RDBA獲取rowid中的rfile#和block_id
11:21:20 SCOTT@ test1 >select dbms_utility.data_block_address_file(16777365) "file",dbms_utility.data_block_address_block(16777365) "block" from dual; file block ---------- ---------- 4 149
5、16進(jìn)制轉(zhuǎn)換
11:43:11 SYS@ test1 >select to_number('01000095','xxxxxxxx') from dual; TO_NUMBER('01000095','XXXXXXXX') -------------------------------- 16777365
6、手工方式轉(zhuǎn)換
rdba: 0x01000095 (4/149) 二進(jìn)制:0000 0001 0000 0000 0000 0000 1001 0101 前10位:(rfile#) 0000 0001 00 =4 后22位: (block#) 00 0000 0000 0000 1001 0101 128+ 16+5=149
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。