暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

深入解析Oracle rowid结构及os层rowid生成工具分享

数据库技术笔记 2021-02-04
1375

一、概念介绍



         Oracle数据库使用rowid标识行。在数据库内部,rowid是一个保存数据库访问一行所需信息的结构。rowid不是物理地存储在数据库中,而是从存储数据的文件和块中计算出来。

 

二、rowid编码规则



extended rowid包括一个数据对象号。这个rowid类型对每一行的物理地址使用base 64编码。编码字符是A-Z、A-Z、0-9、+和/。

1 rowid编码表

 

 

三、rowid格式



 

selectdbms_rowid.ROWID_CREATE(1,88063,4, 539,0) c_rowid from dual;

 

C_ROWID

------------------

AAAVf/   AAE  AAAAIb  AAA

 


2 ROWIDFormat

 

extended rowid以四部分显示以rowid = OOOOOOFFFBBBBBBRRR为例:

OOOOOO: data object number;

FFF: data file number;

BBBBBB: data block number;

RRR: row number

 

四、手工解析ROWID


select dbms_rowid.ROWID_CREATE(1,88063,4, 539,0) c_rowid from dual;

 

C_ROWID

------------------

AAAVf/   AAE  AAAAIb  AAA

手工解析ROWID

 

五、OS层工具生成ROWID

 


mkdir -p home/oracle/orastar

mv ora_crowid home/oracle/orastar

export PATH=/home/oracle/orastar/:$PATH

4 ora_crowid测试


工具下载:请关注公众号,回复“rowid”。

 

六、说明



1、以上内容为个人多次测试结果,由于个人原因,如有分析不足之处还请见谅及指正。

2、文章涉及内容,请勿生产环境模拟。

 


昨日种种,皆成今我,切莫思量,更莫哀,从今往后,怎么收获,怎么栽。——胡适



感谢您的阅读,如果您觉得有所收获,也欢迎把文章分享给您的朋友。



长按识别二维码关注我们


文章转载自数据库技术笔记,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论