使用ODU恢复oracle被truncate的表数据

1。ODU 介绍

      

      ODU全称为Oracle Database Unloader,是类似于Oracle的DUL的软件,用于直接从Oracle数据库的数据文件中获取表数据。在各种原因造成的数据库不能打开时,用于抢救数据,最大限度地减少数据丢失。

      支持的Oracle数据库版本包括8i,9i,10g,11g   

      今天是在ORACLE11G下测试完成了通过ODU对TRUNCATE的表数据如何进行恢复;

 

2。ODU 版本及下载

3。使用及配置

 

       下载到ODU的Windows版本,是一个ZIP压缩文件,解压缩到一个目录,有如下的文件和目录:

     

 

 config.txt文件是ODU的配置文件,我们不需要理会;

control.txt文件是ODU的数据文件信息文件。你可以理解为类似于Oracle数据库的控制文件,存放了ODU导出数据时需要的Oracle数据文件信息。这个文件需要我们自己配置(手工把数据文件块等信息加入这个配置文件,以便ODU进行读取)

control.txt文件中的数据格式为:

表空间号 文件号 相对文件号 文件名 块大小

通过V$DATAFILE 找到相应的信息,加入配置文件,只需要前4列就好了。

我的配置文件如下,这里的格式怎么样都没关系。

#ts    #fno     #rfno   filename
0 1 1 D:/APP/ADMINISTRATOR/ORADATA/ZFTANG/SYSTEM01.DBF
1 2 2 D:/APP/ADMINISTRATOR/ORADATA/ZFTANG/SYSAUX01.DBF
2 3 3 D:/APP/ADMINISTRATOR/ORADATA/ZFTANG/UNDOTBS01.DBF
4 4 4 D:/APP/ADMINISTRATOR/ORADATA/ZFTANG/USERS01.DBF
6 5 5 D:/APP/ADMINISTRATOR/ORADATA/ZFTANG/EXAMPLE01.DBF
7 6 6 D:/APP/ADMINISTRATOR/ORADATA/ZFTANG/USERS02.DBF
8 7 7 D:/APP/ADMINISTRATOR/ORADATA/ZFTANG/USERS03.DBF

 

4。恢复方法

  

 对于ODU来说,  3.0.7版本及以后,恢复方法比较简单,具体操作如下:下面以TEST_01表进行测试:

检查TEST_01表数据,

然后对于表进行TRUNCATE 操作,truncate table test_01.此时数据已经被清空,我们需要进行恢复/

 

a):把TEST_01表所在的表空间进行OFFLINE操作:alter tablespace USERS offline;

b):启动ODU,启动界面如图所示,进行读取配置:

    

     

 

    c):输入:unload dict;进行扫描,结果如下图:

      

      

  d):scan extent ,根据数据文件块多少等,时间稍微有点长,结果如下

       

 

e):通过自动恢复,进行恢复表数据:unload table username.tablename object auto

   

      

 

  f):设置表空间ONLINE ALTER TABLESPACE USERS ONLINE;

 

       结束。。

 

 

备注:还可以数据不进行恢复,只把数据导出来,

 

         只需要执行命令:

 

ODU> unload table zftang.test_01

Unloading table: T1,object ID: 31388
Unloading segment,storage(Obj#=31388 DataObj#=31388 TS#=11 File#=10 Block#=1465 Cluster=0)

执行完此命令后,会在data目录下生成三个文件:

ZFTANG_TEST_01.ctl是用于sqlldr装入数据所需要的控制文件,ZFTANG_TEST_01.sql是建表SQL脚本,ZFTANG_TEST_01.txt是导出的数据。
我们可以用sql文件建表,然后使用sqlldr装入数据。
--EOF
PRM DUL for oracle恢复truncate截断掉的 Oracle DBA神器:PRM灾难恢复工具,Schema级别数据恢复。PRM For Oracle Database – schema级别oracle数据库数据恢复特性 ,PRM即ParnassusData Recovery Manager是企业级别Oracle数据库灾难恢复工具。PRM可以在无备份的情况下恢复truncated/drop掉的,也可以恢复无法打开的Oracle数据库(Alter Database Open失败)中的数据。 PRM是图形化增强版的Oracle DUL工具,同时具备很多Oracle DUL不具备的特性 情况 当某张被意外truncated掉了,需要恢复其上的所有数据时。空间的多个数据文件均存放在ASM上,且没有任何形式的备份。 注意这边文章针对的是PRM在 数据字典模式下的Truncate恢复选项不可用时使用数据字典模式下的Truncate恢复选项是最简单、易用的一种模式,具体使用见《使用PRM恢复Oracle数据库中误truncate截断的数据》http://www.parnassusdata.com/zh-hans/node/52 PRM 3.0的下载地址: http://parnassusdata.com/sites/default/files/ParnassusData_PRMForOracle_3002.zip PRM 的官方网站: http://www.parnassusdata.com/ PRM背景 PRM恢复数据时存在多种模式, PRM需要知道哪些上的数据块是需要被读取并取出数据的。默认的现形式是直接从segment header数据段头里获取EXTENT MAP即盘区图,另一种方案就是由PRM自己去构建一个盘区图。 这些盘区图可以通过,PRM的SCAN DATABASE选项来获得: Recovery Wizard => Non-Dictionary Mode,如果是ASM则选择Non-Dictionary Mode(ASM) 执行SCAN Database后会生成SEG$和EXT$的数据到PRM内嵌的数据库中,之后可以选择SCAN TABLES FROM SEGMENTS 或者 SCAN TABLES FROM EXTENTS。 FROM Segments 意味着使用Segment Header中获得的Extent MAP信息,而FROM Extents意味着使用PRM自己扫描获得的EXTENT信息。 请注意当TRUNCATE发生后, 数据Table的Segment Header中的Extent MAP信息就会被清空了, 但实际存放数据数据块中的行数据还是在哪里的,除非被其他数据/索引的增长而覆盖了。 所以当Truncate发生后选择SCAN TABLES FROM SEGMENT 是找不回数据的,必须使用SCAN TABLES FROM EXTENTS, EXTENT的信息是PRM自己去数据文件中扫描获得的,所以只要有数据的地方PRM就会自己去找到。 除了Truncate需要使用到 SCAN TABLES FROM EXTENTS之外对于DROP TABLE恢复也可以用到SCAN TABLES FROM EXTENTS , 总之当Segment Header找不到(可能存放Segment Header的数据文件丢失了)、或者已损坏(可能Segment Header的数据块被损坏了)、或者其中的Extent Map数据无效(Truncate、DROP或逻辑损坏)时都可以使用SCAN TABLES FROM EXTENTS 。 但是如果不存在上述的问题时,建议用SCAN TABLES FROM SEGMENTS ,因为从Segment Header获取信息更方便也更高效一些。 在PRM中同一个程序实例 同时只能使用SCAN TABLES FROM SEGMENTS 或者 SCAN TABLES FROM EXTENTS 中的一个。 使用SCAN TABLES FROM EXTENTS 后需要找到对应被TRUNCATE掉的的原始DATA_OBJECT_ID,即左侧属性图中的一个对象,并将其DataBridge 数据搭桥传输到目标数据库中即可。 用户truncate误删 schema下的若干数据,无法使用flashback query等技术恢复数据,尝试从之前的全备份中恢复数据库restore速度较快,但是archivelog恢复时由于HP data Protecter的不明原因导致归档恢复十分缓慢,缓慢一个归档往往要几分钟,而需要restore数百个归档,时间上无法接受。 该案例通过PRM-DUL直接在字典模式下恢复truncate数据的功能,在不到一个小时内就恢复了数十万条数据,虽然我们无法保证不丢失一条数据,但至少帮助用户在最短时间内恢复了主要业务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值