WEB开发网
开发学院数据库Oracle oracle8的ROWID结构 阅读

oracle8的ROWID结构

 2007-05-09 12:10:44 来源:WEB开发网   
核心提示:1、为什么使用ROWIDORACLE把ROWID作为B-树和其内部算法标示ROW的唯一标示,在ORACLE8以前的版本中,oracle8的ROWID结构,ROWID标示FILE、BLOCK、ROW NUMBER,只用一个数字代表FILE号,而且不重复,最开始的时候,在ORACLE8中,一个DATAFILE有两个数字代表

1、为什么使用ROWID 

ORACLE把ROWID作为B-树和其内部算法标示ROW的唯一标示。 

在ORACLE8以前的版本中,ROWID标示FILE、BLOCK、ROW NUMBER,只用一个数字代表FILE号。 

在ORACLE8中,一个DATAFILE有两个数字代表: 

一个绝对值,是整个数据库唯一的。可以看DBA_DATA_FILES中的FILE_ID。 

一个相对值,在TABLESPACE中是唯一的,可以看DBA_DATA_FILES中的RELATIVE_FNO。 

新的ROWID使用相对值,所以必须存放SEGMENT的标示,否则就会混淆。所以ORACLE8在ROWID中加入对象的SEGMENT号,用来标示TABLE或者PARTITION。 

2、ROWID的结构 

使用base-64代码,包括a-z,A-Z,0-9,+,-。一共18位。 

1-6位:代表OBJECT 

7-9位:文件相对值 

10-15:文件中的BLOCK 

16-18:BLOCK中的SLOT值 

3、TABLESPACE-Relative寻址方式 

使用的是TABLESPACE-Relative寻址方式,多个文件可以有相同的相对值,因为它们属于不同的TABLESPACE,所以不能从新的ROWID得到绝对地址,但是这没有问题,因为当要处理某个OBJECT时,已经能确定它属于哪个TABLESAPCE了。在TABLES SPACE中,文件相对值是唯一的,所以ROWID还是可以唯一标示一个OBJECT。TABLE  SPACE-Relative寻址方式是ORACLE8中支持超大数据库的关键技术。 

4、DATA OBJECT NUMBER 

DATA OBJECT NUMBER用于指示SEGMENT,所有SEGMENT都有DATA OBJECT NUMBER,存放在每个DATA BLOCK中,而且不重复。 

最开始的时候,DBA_OBJECTS.OBJECT_ID=DBA_OBJECTS.DATA-OBJECT_ID,但是在上述情况下DATA-OBJECT_ID会在如下情况下增加 

TRUNCATE TABLE 

1 2 3  下一页

Tags:oracle ROWID 结构

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接