Oracle 10g 中的ROWID詳解
首先使用select * from v$version; 查詢Oracle資料庫當前的版本
SQL> select * from v$version;
BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.3.0 - Prod
PL/SQL Release 10.2.0.3.0 - Production
CORE 10.2.0.3.0 Production
TNS for 32-bit Windows: Version 10.2.0.3.0 - Production
NLSRTL Version 10.2.0.3.0 - Production
我們首先執行一條查詢:
SQL> select rowid,employee_id,first_name,last_name,job_id
2 from employees
3 where rownum<11;
ROWID EMPLOYEE_ID FIRST_NAME LAST_NAME JOB_ID
------------------ ----------- -------------------- ------------------------- ----------
AAAMieAAFAAAABUAAA 198 Donald OConnell SH_CLERK
AAAMieAAFAAAABUAAB 199 Douglas Grant SH_CLERK
AAAMieAAFAAAABUAAC 200 Jennifer Whalen AD_ASST
AAAMieAAFAAAABUAAD 201 Michael Hartstein MK_MAN
AAAMieAAFAAAABUAAE 202 Pat Fay MK_REP
AAAMieAAFAAAABUAAF 203 Susan Mavris HR_REP
AAAMieAAFAAAABUAAG 204 Hermann Baer PR_REP
AAAMieAAFAAAABUAAH 205 Shelley Higgins AC_MGR
AAAMieAAFAAAABUAAI 206 William Gietz AC_ACCOUNT
AAAMieAAFAAAABYAAA 100 Steven King AD_PRES
已選擇10行。
可以看到查詢結果中所顯示的ROWID的值。
Oracle rowid
Oracle入門基礎教程:rowid詳解
Oracle 中ROWNUM用法總結,ROWNUM 與 rowid 區別
rowid走索引之嫌疑犯抓獲
Oracle利用rownum和rowid分頁
Oracle的ROWID用來唯一標識表中的一條記錄,是這條資料在資料庫中存放的物理地址。
Oracle的ROWID偽列的值並不儲存在資料庫中。Oracle在執行查詢時計算其值。Oracle的物理擴充ROWID有18位,每位採用64位編碼,分別用A~Z、a~z、0~9、+、/共64個字元表示。A表示0,B表示1,……Z表示25,a表示26,……z表示51,0表示52,……,9表示61,+表示62,/表示63。
通過DBMS_ROWID包可以把ROWID值轉換成有意義的資訊。
SQL> select dbms_rowid.rowid_relative_fno(rowid),employee_id
2 from employees
3 where employee_id=200;
DBMS_ROWID.ROWID_RELATIVE_FNO(ROWID) EMPLOYEE_ID
------------------------------------ -----------
5 200
執行下面的查詢,可以獲得該資料存放區的物理資料檔案的資訊:
SQL> col tablespace_name format a20;
SQL> col file_name format a80;
SQL> select file_name, tablespace_name from dba_data_files where relative_fno = 5;
FILE_NAME TABLESPACE_NAME
-------------------------------------------------------------------------------- --------------------
E:\ORACLE\PRODUCT\10.2.0\ORADATA\KEYMENDB\EXAMPLE01.DBF EXAMPLE
在SQL語句的SELECT和WHERE子句中都可以使用ROWID的值。大多數情況下,ROWID唯一標識一行。然而,行有可能儲存在同一個聚簇中的不同表中,因此包含具有相同ROWID的行。
理解ROWID首先需要理解它的兩個方面:ROWID的特性和ROWID的結構。
一、ROWID的特性
(1)rowid是一個偽列,是用來確保表中行的唯一性,它並不能指示出行的物理位置,但可以用來定位行。
(2)rowid是儲存在索引中的一組既定的值(當行確定後)。我們可以像表中普通的列一樣將它選出來。
(3)利用rowid是訪問表中一行的最快方式。
(4)rowid需要10個位元組來儲存,顯示為18位的字串。
二、ROWID的結構
rowid的組成結構為:
data object number(6位字串) relative file number(3位字串) block number(6位字串) row number(3位字串),如:AAAMieAAFAAAABUAAC
64編碼的物理地址,編碼字元是A-Z, a-z, 0-9, +,and/.
由4部分組成OOOOOOFFFBBBBBBRRR (obj#file#block#row#)
OOOOOO -–data object number
FFF –-資料表空間相對的資料檔案號
BBBBBB –-塊號
RRR ---行號
當如下情況發生時,rowid將發生改變:
(1)對一個表做資料表空間的移動後
(2)對一個表進行了EXP/IMP