本文共 1578 字,大约阅读时间需要 5 分钟。
1、rowid是一个伪列,是用来确保表中行的唯一性,它并不能指示出行的物理位置,但可以用来定位行。 2、rowid是存储在索引中的一组既定的值(当行确定后)。我们可以像表中普通的列一样将它选出来。 4、rowid需要10个字节来存储,显示为18位的字符串。 rowid的组成结构为: data object number(6位字符串) relative file number(3位字符串) block number(6位字符串) row number(3位字符串),如:AAANS3AABAAAPPqAAA 5、我们可以借助oracle提供的包dbms_rowid,来对rowid进行解析从而获取关于行的相关信息: 2 rowid, 3 dbms_rowid.rowid_object(rowid) obj_id, 4 dbms_rowid.rowid_relative_fno(rowid) df#, 5 dbms_rowid.rowid_block_number(rowid) blknum, 6 dbms_rowid.rowid_row_number(rowid) rowno 7 from t; 一般来说,当表中的行确定后,rowid就不会发生变化。 但当如下情况发生时,rowid将发生改变: 1、对一个表做表空间的移动后 2、对一个表进行了EXP/IMP 在Oracle中如何利用Rowid查找和删除表中的重复记录 如果我利用命令:delete from t2 where a='zongjun';的话,两行内容将全部删掉,而我想删掉其中的一行内容呢? 这样我们就删掉了重复的内容,请记住rowid是完全不一样的。 但是这样只能适合数据少的表,但是在大型的数据库当中,一个表可能有上千万行的内容,因此我们不可能一条一条的去查找并且删除。我们可以利用min(rowid)或max(rowid)来保留一条重复的内容,删除其余所有的重复内容;如下表 ID NAME ---------- -------- 1 zzj 2 wang 3 li 1 zzj 1 zzj 1 zzj 1 zzj 1 gang 1 gang 以上有很多内容是相同的,现在要删除完全一样的内容,各自保留一行即可: SQL> delete from tt where tt.rowid not in (select min(rowid) from tt group by id,name); ID NAME ---------- -------- 1 zzj 2 wang 3 li 1 gang 5行已被删除,但是现在还有id一样的行,要保留一行,如下 SQL> delete from tt where tt.rowid not in (select min(rowid) from tt group by id); ID NAME ---------- -------- 1 zzj 2 wang 3 li 其中的min(rowid)可以换成max(rowid),这样将会保留最大的rowid,而删除其他的。这里只能利用函数min和max保留最大或者最小的。 本文转自 zhangzj1030 51CTO博客,原文链接:http://blog.51cto.com/tech110/168025 转载地址:http://zpxkm.baihongyu.com/