一、rowid认识
Oracle数据库的表中的每一行数据都有一个唯一的标识符,或者称为rowid,在oracle内部通常就是使用它来访问数据的。rowid需要
10个字节的存储空间,并用18个字符来显示。该值表明了该行在oracle数据库中的物理具体位置。可以在一个查询中使用rowid来表明查询结果中包含该值。
保存rowid需要10个字节或者是80个位二进制位。这80个二进制位分别是:
1. 数据对象编号,表明此行所属的数据库对象的编号,每个数据对象在数据库建立的时候都被唯一分配一个编号,并且此编号唯一。数据对象编号占用大约32位。
2. 对应文件编号,表明该行所在文件的编号,表空间的每一个文件标号都是唯一的。文件编号所占用的位置是10位。
3. 块编号,表明改行所在文件的块的位置块编号需要22位。
4. 行编号,表明该行在行目录中的具体位置行编号需要16位。
Oracle的物理扩展ROWID有18个字符,每位采用64位编码,分别用AZ、az、0~9、+、/共64个字符表示。A表示0,B表示1,……Z表示25,a表示26,……z表示51,0表示52,……,9表示61,+表示62,/表示63。
例如:select rowid,empid from scott.emp;
ROWID EMPNO
AAAR3sAAEAAAACXAAA 7369
AAAR3sAAEAAAACXAAB 7499
二、利用rowid删除重复的记录
delete from dept where rowid not in
(select min(rowid) from dept group by deptno)
本文深入解析Oracle数据库中ROWID的构成与作用,ROWID是Oracle内部用于快速定位每行数据的唯一标识符,由数据对象编号、文件编号、块编号和行编号组成。文章还介绍了如何利用ROWID进行数据查询和删除重复记录的方法。
1120

被折叠的 条评论
为什么被折叠?



