ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 简单总结一下rowid的相关知识

简单总结一下rowid的相关知识

原创 Linux操作系统 作者:oracle_ace 时间:2007-12-17 14:44:55 0 删除 编辑

rowid在磁盘上需要10 个字节的存储空间并使用18 个字符来显示它包含下列组件:

数据对象编号:每个数据对象如表或索引在创建时都分配有此编号,并且此编号在数据库中是唯一的;

相关文件编号:此编号对于一个表空间中的每个文件是唯一的;

块编号:表示包含此行的块在文件中的位置;

行编号:标识块头中行目录位置的位置;

在内部数据对象编号需要32位,相关文件编号需要10位,块编号需要22位,位行编号需要16位,加起来总共是80位或10 个字节,ROWID 使用以64为基数的编码方案来显示该方案将6个位置用于数据对象,编号3个位置用于相关文件编号,6个位置用于块编号,3个位置用于行编号以64为基数的编码方案使用字符A-Z a-z 0-9 + 和/共64 个字符,如下例所示:
AAAB/R AAB AAAGmS AAA

在本例中

AAAB/R   是数据对象编号

AAB     是相关文件编号

AAAGmS  是块编号

AAA      是行编号

这里再版补充一下:
由于block是22位,因此一个数据文件中最多可以有2^22 -1个数据块
2K数据库的数据文件的size最大只能是8G
而依此类推8K数据块的一个数据文件的最大size只能是32G

有个脚本再记录一下:
create or replace function get_rowid
(l_rowid in varchar2)
return varchar2
is
ls_my_rowid  varchar2(200);         
rowid_type  number;         
object_number  number;         
relative_fno  number;         
block_number  number;         
row_number  number; 
begin
dbms_rowid.rowid_info(l_rowid,rowid_type,object_number,relative_fno, block_number, row_number);         
ls_my_rowid := 'Object# is      :'||to_char(object_number)||chr(10)||
  'Relative_fno is :'||to_char(relative_fno)||chr(10)||
  'Block number is :'||to_char(block_number)||chr(10)||
  'Row number is   :'||to_char(row_number);
return ls_my_rowid ;
end;         
/create or replace function get_rowid
(l_rowid in varchar2)
return varchar2
is
ls_my_rowid  varchar2(200);         
rowid_type  number;         
object_number  number;         
relative_fno  number;         
block_number  number;         
row_number  number; 
begin
dbms_rowid.rowid_info(l_rowid,rowid_type,object_number,relative_fno, block_number, row_number);         
ls_my_rowid := 'Object# is      :'||to_char(object_number)||chr(10)||
  'Relative_fno is :'||to_char(relative_fno)||chr(10)||
  'Block number is :'||to_char(block_number)||chr(10)||
  'Row number is   :'||to_char(row_number);
return ls_my_rowid ;
end;         
/
通过此自定义function我们可以很方便的获得rowid的相关信息.

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12361284/viewspace-720/,如需转载,请注明出处,否则将追究法律责任。

下一篇: data block的转储
请登录后发表评论 登录
全部评论

注册时间:2007-12-10

  • 博文量
    284
  • 访问量
    844786