li
  当前位置:主页 > 性能优化 > 文章内容
li
Oracle基本数据类型存储格式浅析(四)——ROWID类型(一)
来源: http://yangtingkun.itpub.net/  作者: yangtingkun    时间:2008-01-26   阅读:6  
本文章共3238字,分3页,当前第1页,快速翻页:
 

Oracle的ROWID用来唯一标识表中的一条记录,是这条数据在数据库中存放的物理地址。

Oracle的ROWID分为两种:物理ROWID和逻辑ROWID。索引组织表使用逻辑ROWID,其他类型的表使用物理ROWID。其中物理ROWID在Oracle的8版本中进行了扩展,Oracle7及以下版本使用约束ROWID,Oracle8及以上版本使用扩展ROWID。本文描述物理扩展ROWID,由于约束ROWID仅仅是为了兼容早期版本,因此不做讨论。


SQL> create table test_rowid (id number, row_id rowid);

表已创建。

SQL> insert into test_rowid values (1, null);

已创建 1 行。

SQL> update test_rowid set row_id = rowid where id = 1;

已更新 1 行。

SQL> commit;

提交完成。

SQL> select rowid, row_id from test_rowid;

ROWID ROW_ID
------------------ ------------------
AAABnRAAGAAAACWAAA AAABnRAAGAAAACWAAA

Oracle的物理扩展ROWID有18位,每位采用64位编码,分别用A~Z、a~z、0~9、 、/共64个字符表示。A表示0,B表示1,……Z表示25,a表示26,……z表示51,0表示52,……,9表示61, 表示62,/表示63。

ROWID具体划分可以分为4部分。

1.OOOOOO:前6位表示DATA OBJECT NUMBER,将起转化位数字后匹配DBA_OBJECTS中的DATA_OBJECT_ID,可以确定表信息。

如上面例子中的DATA OBJECT NUMBER是AAABnR,转化位数字是1×64×64 +39×64 + 17。

SQL> select owner, object_name from dba_objects
2 where data_object_id = 1*64*64 39*64 17;

OWNER OBJECT_NAME

www.ixdba.net


------------------------------ -----------------------------
YANGTK TEST_ROWID

2.FFF:第7到9位表示相对表空间的数据文件号。

上面的例子中是AAG,表示数据文件6。

SQL> select file_name, tablespace_name from dba_data_files where relative_fno = 6;

FILE_NAME TABLESPACE_NAME
--------------------------------------------- ---------------
E:ORACLEORADATATESTYANGTK01.DBF YANGTK

3.BBBBBB:第10到15位表示这条记录在数据文件中的第几个BLOCK中。

上面的例子是AAAACW,转化位数字是2×64+22,表示这条记录在数据文件中的第150个BLOCK。

4.RRR:最后3位表示这条记录是BLOCK中的第几条记录。

上面的例子是AAA,表示第0条记录(总是从0开始计数)。

SQL> alter system dump datafile 6 block 150;

系统已更改。

SQL> select row_id, dump(row_id, 16) dump_rowid from test_rowid;

ROW_ID DUMP_ROWID
------------------ -------------------------------------------------
AAABnRAAGAAAACWAAA Typ=69 Len=10: 0,0,19,d1,1,80,0,96,0,0

找到对应的dump文件,可以发现类型的信息

*** 2004-12-21 17:58:26.000
*** SESSION ID:(13.91) 2004-12-21 17:58:26.000
Start dump data blocks tsn: 6 file#: 6 minblk 150 maxblk 150
buffer tsn: 6 rdba: 0x01800096 (6/150)
scn: 0x0000.2e389c16 seq: 0x01 flg: 0x06 tail: 0x9c160601
frmt: 0x02 chkval: 0xc97d type: 0x06=trans data
Block header dump: 0x01800096
Object id on Block? Y
seg/obj: 0x19d1 csc: 0x00.2e389c0f itc: 2 flg: O typ: 1 - DATA
fsl: 0 fnx: 0x0 ver: 0x01

Itl Xid Uba Flag Lck Scn/Fsc
0x01 0x0003.009.00000057 0x0080004b.0042.56 --U- 1 fsc 0x0000.2e389c16
0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000

data_block_dump,data header at 0x651105c
===============
tsiz: 0x3fa0
hsiz: 0x14
pbl: 0x0651105c
bdba: 0x01800096
76543210
flag=--------
ntab=1
nrow=1
frre=-1
fsbo=0x14



阅读更多内容1 · 2 · 3 · 下一页>>


  上一篇: 物化视图的快速刷新(三)   下一篇: 同时使用数据库链和序列时应注意...
li
 §相关评论  
 热点文章

·Resize datafile导致ASM Crash
·在Oracle10g RAC下新增ASM磁盘
·ORACLE SQL性能优化系列 (一)
·oracle性能调优:管理oracle日志
·oracle RAC环境中系统时钟的调
·why:Rac的心跳线不支持交叉线?
·RAC的VIP及实例依赖关系:版本O
·如何启动DataGuard的备用数据库
·系统表空间IO错误 数据损坏处理
·不幸中的万幸:遭遇ORA-00600 [
·用ORACLE的高级复制实现内外网
li
 编辑推荐
·Resize datafile导致ASM Crash
·在Oracle10g RAC下新增ASM磁盘
·ORACLE SQL性能优化系列 (一)
·oracle性能调优:管理oracle日志
·oracle RAC环境中系统时钟的调
·why:Rac的心跳线不支持交叉线?
·RAC的VIP及实例依赖关系:版本O
·如何启动DataGuard的备用数据库
·系统表空间IO错误 数据损坏处理
·不幸中的万幸:遭遇ORA-00600 [
·用ORACLE的高级复制实现内外网
li
 相关篇章
·物化视图的快速刷新(三)
·数据字典——数据库概念
·Oracle如何根据物化视图日志快速...
·从PUBLIC回收SELECT ANY TABLE权...
·管理分区表和索引——管理员手册
·TO_DATE函数的小问题
·物化视图——数据仓库手册
·将普通表转变为分区表
·全文索引文档显示——标注
·Oracle基本数据类型存储格式浅析...
·同时使用数据库链和序列时应注意...
·定位导致物化视图无法快速刷新的...
·本地分区索引如何确定表空间
·对字符串的“sum”——在Oracle中...
·增加Distinct后查询效率反而提高...
·Oracle基本数据类型存储格式浅析...
·RAC概念
·Redhat AS4上安装64位Oracle9204
·Oracle的在线重定义表功能
·Redhat AS4 for x86_64上安装Ora...
 
li
设为首页 | 关于我们 | 技术服务 | 收藏本站 | 网站地图 | 联系方式 | 本站友情连接