Oracle rowid

Oracle rowid

 

       行的ROWID指出了该行所在的数据文件、数据块以及行在该块中的位置,所以通过ROWID来存取数据可以快速定位到目标数据上,是Oracle存取单行数据的最快方法。

 

  为了通过ROWID存取表,Oracle 首先要获取被选择行的ROWID,或者从语句的WHERE子句中得到,或者通过表的一个或多个索引的索引扫描得到。Oracle然后以得到的

ROWID为依据定位每个被选择的行。

 

扩展ROWID格式为:       

000000             FFF       BBBBBB        RRR

数据对象号   相对文件号   块号     行号

 

个扩展ROWID在硬盘上需要10个字节的存储空间,它是用18个字符来显示。扩展ROWID的组成如下:

1)数据对象号(data object number):被赋予每一个对象,它在一个数据库中是唯一的。

2)相对文件号(relative file number):对同一个表空间中的每一个文件是唯一的。

3)块号(block number):为相对文件中包含数据行的块的位置

4)行号(row number):标识了块中行目录的位置

 

Oracle在内部存储扩展ROWID时,数据对象号需要32位,相对文件号需要10位,块号需要22位,而行号需要16位,加起来总共80位或10个字节。

扩展ROWID的显示是使用一种64位编码。其中:数据对象号为6位,相对文件号为3位,块号6位,而行号为3位。这种64位编码模式使用的字符为:A-Z,a-z,0-9,还有+和/,总共

64个字符。

 

使用ROWID可以定位一个数据库中的任何数据行。因为一个段只能存放在一个表空间内。所以通过使用数据对象号Oracle服务器就可以找到包含数据行的表空间。之后使用表

空间中的相对文件号就可以确定文件,再利用块号就可以确定包含所需数据行的数据块,最后使用行号就可以定位数据行的行目录项。使用行目录项可以定位数据行的起始地址。

 

限制性ROWID:

BBBBBBBB         RRRR      FFFF

块号      行号   文件号

 

限制性ROWID与扩展ROWID最大的区别是它没有数据对象号。限制性ROWID是在Oracle7或之前版本中使用的。Oracle系统在内部存储限制性ROWID时仅用6个字节,因此

它是没有包括数据对象号的。

正因为如此:

ORACLE 7或以前,整个数据库数据文件不得超过1022个

ORACLE 8或以后,现在表空间数不得超过1022个,每个表空间中的数据文件不得超过1022个,整个数据库最多数据文件65533个

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值