溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Oracle Study之案例--Oracle 數(shù)據(jù)塊地址(Block Address)

發(fā)布時間:2020-07-14 21:26:36 來源:網(wǎng)絡(luò) 閱讀:1150 作者:客居天涯 欄目:關(guān)系型數(shù)據(jù)庫

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
向AI問一下細(xì)節(jié)

免責(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)容。

AI