Oracle Study之案例--Oracle 数据块地址(Block Address)

简介:

 Oracle访问数据是以block为单位,本文简单介绍了如何通过Block Address在内存中获取所需要的block。

DBA(data block address):

A DBA is the address of an oracle data block for access purposes.

RDBA (Tablespace relative database block address):

RDBA 是相对数据块地址,是数据所在的地址,rdba可就是rowid 中rfile#+block#

ROWID:

      Oracle在通过Index访问时,通过rowid确定row的位置;我们都知道rowid表示一行的物理地址,一行唯一确定一个rowid,并且在使用中一般不会改变,除非rowid之后在行的物理位置发生改变的情况下才会发生变化。需要注意的是rowid并不会真正存在于表的data block中,但是他会存在于index当中,用来通过rowid来寻找表中的行数据。
     Oracle8以前一个rowid占用6个字节大小的存储空间(10bit file#+22bit block#+16bit row#),那么oracle 8以后这个rowid的存储空间扩大到了10个字节(32bit object#+10bit rfile#+22bit block#+16bit row#),所以数据库中数据库文件个数的限制从整个数据库最多只能有的2^10-1个数据文件,变为了每个表空间中可以最多有2^10-1个数据文件。

     (需要注意的是:local index中存储的rowid是6个字节,而global index中存储的rowid是10个字节)
     那么增加的32bit object#这个前缀主要就是用来定位表空间的,同时这个object#其实对应的就是data_object_id,由于一个段对象只能属于一个表空间,同时data_object_id就是标识了一个段的物理存储id.因此object#+rfile#就可以唯一定位当前的rowid是在那个数据文件上了。
我们可以通过dbms_rowid这个包来转换我们的rowid成不同组成部分:

1
2
3
4
dbms_rowid.rowid_object(rowid) ---> 32bit 
object#dbms_rowid.rowid_relative_fno(rowid) ---> 10bit 
rfile#dbms_rowid.rowid_block_number(rowid) ---> 22bit 
block#dbms_rowid.rowid_row_number(rowid) ---> 16bit row#

案例分析:

1、通过dbms_utility转换地址

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
10 : 33 : 59  SYS@ test1 >desc dbms_utility
FUNCTION DATA_BLOCK_ADDRESS_BLOCK RETURNS NUMBER
  Argument Name                  Type                    In/Out Default?
  ------------------------------ ----------------------- ------ --------
  DBA                            NUMBER                  IN
  
FUNCTION DATA_BLOCK_ADDRESS_FILE RETURNS NUMBER
  Argument Name                  Type                    In/Out Default?
  ------------------------------ ----------------------- ------ --------
  DBA                            NUMBER                  IN
  
FUNCTION MAKE_DATA_BLOCK_ADDRESS RETURNS NUMBER
  Argument Name                  Type                    In/Out Default?
  ------------------------------ ----------------------- ------ --------
  FILE                           NUMBER                  IN
  BLOCK                          NUMBER                  IN

2、通过rowid获取RDBA

1
2
3
4
5
6
7
8
9
10
11
12
11 : 14 : 36  SYS@ test1 >conn scott/tiger
Connected.
11 : 14 : 39  SCOTT@ test1 >select rowid,ename  from  emp  where  rownum= 1 ;
ROWID              ENAME
------------------ ----------
AAAESjAAEAAAACVAAA SMITH
 
11 : 15 : 05  SCOTT@ test1 >select dbms_rowid.ROWID_RELATIVE_FNO(rowid) ,dbms_rowid.ROWID_BLOCK_NUMBER(rowid)  from  emp  where  rownum= 1 ;
 
DBMS_ROWID.ROWID_RELATIVE_FNO(ROWID) DBMS_ROWID.ROWID_BLOCK_NUMBER(ROWID)
------------------------------------ ------------------------------------
                                    4                                   149

3、通过Dump获取block信息

11:42:16 SYS@ test1 >alter system dump datafile 4 block 149;

System altered.

Block dump  from  cache:
Dump of buffer cache  at  level  4  for  tsn= 4 , rdba= 16777365
Block dump  from  disk:
buffer tsn:  4  rdba:  0x01000095  ( 4 / 149 )
scn:  0x0000. 009722f6 seq:  0x01  flg:  0x04  tail:  0x22f60601
frmt:  0x02  chkval:  0x52a5  type:  0x06 =trans data
Hex dump of block: st= 0 , typ_found= 1
Dump of memory  from  0x008E8200  to  0x008EA200
8E8200  0000A206  01000095  009722F6  04010000   [........."......]
......
Block header dump:   0x01000095
  Object id  on  Block? Y
  seg/obj:  0x44a3   csc:  0x00. 9722f6  itc:  2   flg: E  typ:  1  - DATA
      brn:  0   bdba:  0x1000090  ver:  0x01  opc:  0
      inc:  0   exflg:  0
  Itl           Xid                  Uba         Flag  Lck        Scn/Fsc
0x01    0x001b. 01f.0000007a   0x01c01c55. 0121.23   C-U-     0   scn  0x0000. 00971d50
0x02    0x0000. 000.00000000   0x00000000. 0000.00   ----     0   fsc  0x0000. 00000000
bdba:  0x01000095
data_block_dump,data header  at  0x8e8264
......
block_row_dump:
tab  0 , row  0 , @ 0x1f72
tl:  38  fb: --H-FL-- lb:  0x0   cc:  8
col   0 : [  3 ]  c2 4a  46
col   1 : [  5 ]   53  4d  49  54  48
col   2 : [  5 ]   43  4c  45  52  4b
col   3 : [  3 ]  c2  50  03
col   4 : [  7 ]   77  b4 0c  11  01  01  01
col   5 : [  2 ]  c2  09
col   6 : *NULL*
col   7 : [  2 ]  c1  15
tab  0 , row  1 , @ 0x1f47
......

4、通过RDBA获取rowid中的rfile#和block_id

1
2
3
4
11 : 21 : 20  SCOTT@ test1 >select dbms_utility.data_block_address_file( 16777365 "file" ,dbms_utility.data_block_address_block( 16777365 "block"  from  dual;
       file      block
---------- ----------
          4         149

5、16进制转换

1
2
3
4
11 : 43 : 11  SYS@ test1 >select to_number( '01000095' , 'xxxxxxxx' from  dual;
TO_NUMBER( '01000095' , 'XXXXXXXX' )
--------------------------------
                         16777365

6、手工方式转换

1
2
3
4
5
rdba:  0x01000095  ( 4 / 149 )
二进制: 0000  0001  0000  0000  0000  0000   1001  0101
10 位:(rfile#)  0000  0001  00   = 4
22 位: (block#)  00  0000  0000  0000   1001  0101
                   128 16 + 5 = 149









本文转自 客居天涯 51CTO博客,原文链接:http://blog.51cto.com/tiany/1590972,如需转载请自行联系原作者
目录
相关文章
|
10月前
|
存储 Oracle 关系型数据库
服务器数据恢复—光纤存储上oracle数据库数据恢复案例
一台光纤服务器存储上有16块FC硬盘,上层部署了Oracle数据库。服务器存储前面板2个硬盘指示灯显示异常,存储映射到linux操作系统上的卷挂载不上,业务中断。 通过storage manager查看存储状态,发现逻辑卷状态失败。再查看物理磁盘状态,发现其中一块盘报告“警告”,硬盘指示灯显示异常的2块盘报告“失败”。 将当前存储的完整日志状态备份下来,解析备份出来的存储日志并获得了关于逻辑卷结构的部分信息。
|
11月前
|
存储 Oracle 关系型数据库
oracle数据恢复—oracle数据库执行错误truncate命令的数据恢复案例
oracle数据库误执行truncate命令导致数据丢失是一种常见情况。通常情况下,oracle数据库误操作删除数据只需要通过备份恢复数据即可。也会碰到一些特殊情况,例如数据库备份无法使用或者还原报错等。下面和大家分享一例oracle数据库误执行truncate命令导致数据丢失的数据库数据恢复过程。
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。
|
存储 Oracle 关系型数据库
数据库数据恢复—Oracle ASM磁盘组故障数据恢复案例
Oracle数据库数据恢复环境&故障: Oracle ASM磁盘组由4块磁盘组成。Oracle ASM磁盘组掉线 ,ASM实例不能mount。 Oracle数据库故障分析&恢复方案: 数据库数据恢复工程师对组成ASM磁盘组的磁盘进行分析。对ASM元数据进行分析发现ASM存储元数据损坏,导致磁盘组无法挂载。
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。
|
Oracle 关系型数据库 数据库
oracle数据恢复—Oracle数据库文件损坏导致数据库打不开的数据恢复案例
打开oracle数据库时报错,报错信息:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。急需恢复zxfg用户下的数据。 出现上述报错的原因有:控制文件损坏、数据文件损坏、数据文件与控制文件的SCN不一致等。数据恢复工程师对数据库文件做进一步检测分析后发现sysaux01.dbf文件有坏块。修复sysaux01.dbf文件,启动数据库依然有许多查询报错。export和data pump工具无法使用,查询告警日志并分析报错,确认发生上述错误的原因就是sysaux01.dbf文件损坏。由于该文件损坏,从数据库层面无法修复数据库。由于system和用户表空间的数据文件是正常的,
|
8月前
|
Oracle 关系型数据库 Linux
【赵渝强老师】Oracle数据库配置助手:DBCA
Oracle数据库配置助手(DBCA)是用于创建和配置Oracle数据库的工具,支持图形界面和静默执行模式。本文介绍了使用DBCA在Linux环境下创建数据库的完整步骤,包括选择数据库操作类型、配置存储与网络选项、设置管理密码等,并提供了界面截图与视频讲解,帮助用户快速掌握数据库创建流程。
673 93
|
7月前
|
Oracle 关系型数据库 Linux
【赵渝强老师】使用NetManager创建Oracle数据库的监听器
Oracle NetManager是数据库网络配置工具,用于创建监听器、配置服务命名与网络连接,支持多数据库共享监听,确保客户端与服务器通信顺畅。
371 0
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
1311 64

推荐镜像

更多