国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

ORACLE中的ROWID

2024-08-29 13:44:57
字體:
來源:轉載
供稿:網(wǎng)友

   我們可能對Oracle的rowid的使用并不生疏,不過,假如仔細分析一下,發(fā)現(xiàn)其還是有些知識點。
1、rowid是一個偽列,是用來確保表中行的唯一性,它并不能指示出行的物理位置,但可以用來定位行。 2、rowid是存儲在索引中的一組既定的值(當行確定后)。我們可以像表中普通的列一樣將它選出來。
3、利用rowid是訪問表中一行的最快方式。
4、rowid需要10個字節(jié)來存儲,顯示為18位的字符串。
rowid的組成結構為:
data object number(6位字符串)+relative file number(3位字符串)+block number(6位字符串)+row number(3位字符串),如:AAAADeAABAAAAZSAAA
5、我們可以借助oracle提供的包dbms_rowid,來對rowid進行解析從而獲取關于行的相關信息:
bossdb-SQL>select
2 rowid,
3 dbms_rowid.rowid_object(rowid) obj_id,
4 dbms_rowid.rowid_relative_fno(rowid) df#,
5 dbms_rowid.rowid_block_number(rowid) blknum,
6 dbms_rowid.rowid_row_number(rowid) rowno
7 from p_test where rownum<5;
ROWID OBJ_ID DF# BLKNUM ROWNO
------------------ ---------- ---------- ---------- ----------
AAAQ+tAANAAAC6SAAA 69549 13 11922 0 AAAQ+tAANAAAC6SAAB 69549 13 11922 1 AAAQ+tAANAAAC6SAAC 69549 13 11922 2 AAAQ+tAANAAAC6SAAD 69549 13 11922 3
我們可以看到,通過rowid_row_number得到的行號是從0開始的,這是和rownum偽列的一個不同之處。我猜測rowid_row_number在求行號的時候是計算首行的偏移量。

一般來說,當表中的行確定后,rowid就不會發(fā)生變化。
但當如下情況發(fā)生時,rowid將發(fā)生改變:
1、對一個表做表空間的移動后
2、對一個表進行了EXP/IMP后

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 卢湾区| 土默特左旗| 盐山县| 耿马| 峨眉山市| 莱西市| 洪湖市| 凤山县| 巴彦淖尔市| 友谊县| 永川市| 泽普县| 镇宁| 疏附县| 城步| 临夏县| 津南区| 繁昌县| 海林市| 道真| 卢龙县| 黔西| 天台县| 萨迦县| 宁乡县| 玛纳斯县| 方城县| 高清| 三门县| 新巴尔虎左旗| 大兴区| 阜新市| 景德镇市| 甘肃省| 沧州市| 伊宁市| 舞钢市| 洛川县| 贵溪市| 太康县| 平武县|