Oracle ROWID与UROWID

Oracle使用rowid数据类型存储行地址,rowid可以分成两种,分别适于不同的对像

Physical rowids:存储ordinary table,clustered table,table partition and subpartition,indexe,index partition and subpartition

Logical rowids : 存储IOT的行地址

另一种rowid类型叫universal rowed(UROWID),支持上述physical rowid和logical rowed,并且支持非oracle table, 即支持所有类型的rowid, 但COMPATIBLE必须在8.1或以上.

1.1 ROWID伪列

每个表在oracle内部都有一个ROWID伪列,它在所有sql中无法显示,不占存储空间; 它用于从表中查询行的地址或者在where中进行参照,一个例子如下:

SELECT ROWID, last_name FROM employees;

Oracle内部使用保留在ROWID伪列中的值构建索引结构

再次强调一次,rowid伪列不存储在数据库中,它不是数据库数据,这是从database及table的逻辑结构来说的,事实上,在物理结构上,每行由一个或多个row pieces组成,每个row piece的头部包含了这个piece的address,即rowid.从这个意义上来说,rowid还是占了磁盘空间的.

我们在创建表时,可以为列指定为rowid数据类型,但oracle并不保证列中的数据是合法的rowid值,必须由应用程序来保证, 另外,类型为rowid的列需要6 bytes存储数据

1.2, physical rowids

只在行存在,它的物理地址rowid就不会变化,除非export/import,根据rowid可以直接定位到block去fetch数据,所以physical兼具有高稳定(stability)和高性能(performance)的特点.

这里要注意一点,对于clustered table来说,根据它的存储特点,在同一个block中的不同table的行可能具有同一个rowid; 而nonclustered table,每一行或初始行片(initial row piece)都有唯一的rowid

要注意rowid的地址固定的特点,在一个block的某一行被delete并commit后,它占据的address可以被其它事务新insert的行重用.

Physical rowid可以是下面任一一种格式:

1) Extended rowid

使用表空间相关的数据块地址,8i及以上使用这种格式

2) Restricted rowid

使用数据库范围的数据址地址,oracle 7或更早前的版本使用

1.2.1 extened rowid

扩展行地址是64编码的物理地址,编码字符是A-Z, a-z, 0-9, +, and /.

由4部分组成 OOOOOOFFFBBBBBBRRR (obj#file#block#row#)

OOOOOO -–data object number

FFF –-表空间相对的数据文件号

BBBBBB –-块号

RRR ---行号

注意不是16进制表示

SQL> select rowid,name from obj$ where rownum<=10;

ROWID              NAME

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

AAAAASAABAAAAB6ABc ACCESS$

AAAAASAABAAAC1QAAK AGGXMLIMP

AAAAASAABAAAC1QAAL AGGXQIMP

AAAAASAABAAAGiRAAI ALERT_QT

AAAAASAABAAAGiRAAh ALERT_QUE

AAAAASAABAAAGujAAo ALERT_QUE$1

AAAAASAABAAAGujAAp ALERT_QUE$1

AAAAASAABAAAGiRAAf ALERT_QUE_N

AAAAASAABAAAGiRAAe ALERT_QUE_R

AAAAASAABAAAGiRAAG ALERT_TYPE

我们可以使用dbms_rowid从extened rowid中抽取各部分信息 ,或者将extened rowid转换成restricted rowed,详细的信息参见sys.dbms_rowid的规范

#根据rowid抽块对像编号

SQL> select dbms_rowid.rowid_object(‘AAAAASAABAAAGiRAAG‘) obj#  from dual;

OBJ#

----------

18

#根据rowid抽取表空间相对文件号

SQL> select dbms_rowid.rowid_relative_fno(‘AAAAASAABAAAGiRAAG‘) rfile# from dual;

RFILE#

----------

1

#根据rowid抽取块号

SQL> select dbms_rowid.ROWID_BLOCK_NUMBER(‘AAAAASAABAAAGiRAAG‘) block# from dual;

BLOCK#

----------

26769

#根据rowid抽取行号

SQL> select dbms_rowid.rowid_row_number(‘AAAAASAABAAAGiRAAG‘) row#  from dual;

ROW#

----------

6

#extended rowid转换成为restricted rowid

SQL> select dbms_rowid.rowid_to_restricted(‘AAAAASAABAAAGiRAAG‘,0) restricted_rowid  from dual;

RESTRICTED_ROWID

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

00006891.0006.0001

1.2.2 restricted rowid

限制地址行号与扩展地址行号编码方式不一样,它在内部使用二进制方式表示,当用select查询时,会转换成varchar2/16进制的混合形式,它的组织方式如下:

BBBBBBBB.RRRR.FFFF  (block#.row#.file#)

注意,这里的文件号是绝对文件号,而extended rowid中是相对文件号(相对表空间)

Restricted rowid中不再有object number,因为从绝对文件号可以唯一确定数据块

样例可以参考前面的00006891.0006.0001

另外请注意, 块中的行号是从0开始

除了用dbms_rowid来抽取rowid的不同部分外,也可以用substr

#extended rowid

SQL> SELECT ROWID,

文章来自http://blog.itpub.net/94384/viewspace-600306/

时间: 2024-11-05 18:46:08

Oracle ROWID与UROWID的相关文章

Oracle ROWID详解

1.ROWID定义 ROWID:数据库中行的全局唯一地址 对于数据中的每一行,rowid伪列返回行的地址.rowid值主要包含以下信息: 对象的数据对象编号 该行所在的数据文件中的数据块 该行中数据块的位置(第一行是0) 数据行所在的数据文件(第一个文件是1).该文件编号是相对于表空间. 通常来说,一个rowid值唯一标识数据中的一行.然而,存储在同一聚簇中不同的表可以有相同的rowid. 2.扩展ROWID 从Oracle 8i开始使用扩展rowid标识行物理地址 扩展rowid使用base6

oracle rowid 使用

ROWID是数据的详细地址,通过rowid,oracle可以快速的定位某行具体的数据的位置. ROWID可以分为物理rowid和逻辑rowid两种.普通的堆表中的rowid是物理rowid,索引组织表(IOT)的rowid是逻辑rowid.oracle提供了一种urowid的数据类型,同时支持物理和逻辑rowid.本文主要关注物理rowid 物理rowid又分为扩展rowid(extended rowid)和限制rowid(restricted rowid)两种格式.限制rowid主要是orac

ORACLE rowid,file# 和 rfile#

rowid简介 rowid就是唯一标志记录物理位置的一个id,在oracle 8版本以前,rowid由file#+block#+row#组成,占用6个bytes的空间,10 bit 的 file# ,22bit 的 block# ,16 bit 的 row#. 从oracle 8开始rowid变成了extend rowid,由data_object_id#+rfile#+block#+row#组成,占用10个bytes的空间, 32bit的 data_object_id#,10 bit 的 rf

Oracle ROWID具体解释

1.ROWID定义 ROWID:数据库中行的全局唯一地址 对于数据中的每一行,rowid伪列返回行的地址.rowid值主要包括下面信息: 对象的数据对象编号 该行所在的数据文件里的数据块 该行中数据块的位置(第一行是0) 数据行所在的数据文件(第一个文件是1).该文件编号是相对于表空间. 通常来说.一个rowid值唯一标识数据中的一行.然而,存储在同一聚簇中不同的表能够有同样的rowid. 2.扩展ROWID 从Oracle 8i開始使用扩展rowid标识行物理地址 扩展rowid使用base6

Oracle rowid

一.Rowid rowid是伪列(pseudocolumn),伪劣的意思是实际上这一列本身在数据字典中并不存在,在查询结果输出时它被构造出来的. rowid并不会真正存在于表的data block中,但是他会存在于index当中,用来通过rowid来寻找表中的行数据 二.Rowid的结构 限制rowid:用于早期Oracle版本(Oracle 8 以前),rowid由(10 bit)file#+(22 bit)block#+(16 bit)row#组成,占用6个bytes的空间 注:file#为

ORACLE rowid切分大表

通过如下sql获取rowid切分范围 SELECT rownum || ', ' || ' rowid between ' || chr(39) || dbms_rowid.rowid_create(1, DOI, lo_fno, lo_block, 0) || chr(39) || ' and ' || chr(39) || dbms_rowid.rowid_create(1, DOI, hi_fno, hi_block, 1000000) || chr(39) data FROM (SELE

oracle函数详解

Oracle 数据库中 SQL 分析的主要优势 Oracle 数据库中分析功能和特性提供以下主要优势: 1. 提高开发人员产能 — 开发人员可以通过更清晰.更简洁的 SQL 代码执行复杂分析.现在可以使用一条 SQL 语句表示复杂任务,编写和维护速度更快.效率更高. 2. 提高查询速度 — 数据库中分析支持的处理优化可大幅提高查询性能.以前需要自联接或复杂过程处理的操作现在可以用原生 SQL 执行. 3. 改善可管理性 — 应用程序共享一个公共的关系环境,而非数据结构不兼容的计算引擎组合,因此可

谈oracle数据比对(DBMS_COMPARISON)

今天是2014-08-19,我今天收到csdn给我发的申请博客专家的邀请,自己感觉实在惭愧啊.自从换了工作也一直没有精力在写点东西了.今天我一个同事,在群里贴出了一个数据比对的包(DBMS_COMPARISON),但是这个包相比用的比较少.所以今天就谈谈这个工具包的使用吧. 对于经常完数据迁移的朋友来说,在数据挪动之后,最重要也是最关键和最关心的一个问题是,目标端和源端的数据是否一致.数据的一致是否关系着大型oracle数据库数据迁移的成败与否.目前很多公司都开始研发自己的对比工具,如dsg的基

作为一个新手的Oracle(DBA)学习笔记【转】

一.Oracle的使用 1).启动 *DQL:数据查询语言 *DML:数据操作语言 *DDL:数据定义语言 DCL:数据控制语言 TPL:事务处理语言 CCL:指针控制语言 1.登录 Win+R—cmd—>sqlplus “/as sysdba” //以sysdba用户登录,这样可以管理权限,添加用户等 Win+R—cmd—>sqlplus username/password //以指定用户名密码登录 win+R —> cmd —–> sqlplus //按照提示,输入用户名密码