【深入】體系結構-001-索引內容

Kevin_Weig發表於2018-04-19
1、索引簡單理解就是一行的rowid,是唯一標識此行的“身份證”
    注:rowid 是偽列,每一行的 rowid 是全域性唯一的

2、rowid 18 位, 64 進位制
AAAR+RAAHAAAACTAAH  7788   SCOTT   比如這行,有兩個欄位eno和ename,偽列是18位64進位制的數字

這個18位rowid包括:所在表的物件號 資料檔案號 塊號  塊行號
                            6 位物件號, 3 位檔案號, 6 位塊號, 3 位行號

3、如何獲取
表對應的物件號
col object_name for a20
select object_id,object_name,object_type
from dba_objects where owner='SCOTT' and object_name='EMP';

表空間對應資料檔案號
select OWNER,TABLE_NAME,TABLESPACE_NAME from dba_tables
where owner='SCOTT' and table_name='EMP';
select FILE_NAME,FILE_ID,TABLESPACE_NAME from dba_data_files;

段中塊號範圍
select extent_id,segment_name,bytes/1024 k,blocks,file_id,block_id
from dba_extents where owner='SCOTT' and segment_name='EMP';

物件號-資料檔案號-塊號-行號
select rowid,
dbms_rowid.rowid_object(rowid) object#,
dbms_rowid.rowid_relative_fno(rowid) datafile#,
dbms_rowid.rowid_block_number(rowid) block#,
dbms_rowid.rowid_row_number(rowid) row#
from emp where empno=7788;

emp 表中 7788 這行資料對應的物件 87108, 4號資料檔案, 151號塊中的,第7行


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31476473/viewspace-2153119/,如需轉載,請註明出處,否則將追究法律責任。

相關文章