ROWID 是 Oracle 中一种唯一标识物理数据库中一行的专有数据类型,因为它唯一且持久,且可以在行被移动或更新时保持不变。优点包括检索速度快,可以使用 ROWID 伪列获取,并用于快速查找行、比较行和移动行。

Oracle 中的 ROWID 数据类型
什么是 ROWID?
ROWID 是 Oracle 专有的数据类型,它唯一标识物理数据库中的一行数据。
为什么使用 ROWID?
使用 ROWID 有以下几个好处:
- 唯一性:每个 ROWID 在表空间中都是唯一的,即使在表被删除、重新创建或导入导出后也是如此。
- 持久性:ROWID 在行被移动或更新时不会更改。
- 性能:检索使用 ROWID 标识的行比使用其他标识符(如主键或唯一约束)更快。
ROWID 的结构
技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作
ROWID 的结构取决于 Oracle 版本:
- Oracle 10g 及更早版本:ROWID 由 18 个字节组成,包含文件号、数据块地址和行标识。
- Oracle 11g 及更高版本:ROWID 由 10 个字节组成,包含文件号和数据块地址,行标识不再包含在 ROWID 中。
获取 ROWID
可以使用 ROWID 伪列获取行的 ROWID:
SELECT ROWID FROM table_name WHERE ...;
使用 ROWID
ROWID 可以用于以下目的:
- 查找行:使用 ROWID 可以快速查找特定行,即使行标识符(如主键)未知。
- 比较行:可以比较 ROWID 以确定两行是否在物理上相同。
- 行迁移:ROWID 可用于在不同表空间或数据库之间移动行。









