设为首页 收藏本站
查看: 484|回复: 0

[经验分享] oracle中truncate table后的数据恢复

[复制链接]

尚未签到

发表于 2016-7-29 10:53:44 | 显示全部楼层 |阅读模式
  前几天在工作中不小心truncate了一个表, 而该表中的数据又是很重要的数据。并且该表数据又没有备份的,有备份的也不是最新的,一时之间不知如何是好。在网上找了很多资料,但没有一个很适合的,有适合的但又没详细说明,很无奈。经过多方面的查找,以下是我综合网上的资料,成功恢复表数据的详细步骤,供大家参考。以便遇到同样的问题,可以很好的恢复。
  1、首先下载odu数据恢复工具,然后解压。(odu工具见附件)
2、查询数据文件路径相关信息:select ts#,file#,rfile#,name,BLOCK_SIZE from v$datafile;
   将其结构填入odu目录下的control.txt文件中
   格式如下:
#ts #fno   #rfno     filename                                          block_size
         0          1          1 /bbdata/hzdb/system01.dbf                                                              8192
         1          2          2 /bbidx/hzdb/undotbs01.dbf                                                              8192
         3          3          3 /bbidx/hzdb/indx01.dbf                                                                 8192
         4          4          4 /bbdata/hzdb/tools01.dbf                                                               8192
         5          5          5 /bbdata/hzdb/users01.dbf                                                               8192
         6          6          6 /bbdata/hzdb/REPORT.dbf                                                                8192
         7          7          7 /bbdata/hzdb/RESERVE.dbf                                                               8192
         8          8          8 /bbdata/hzdb/WZHTBS.dbf                                                                8192
         9          9          9 /bbdata/hzdb/perfstat01.dbf                                                            8192
3、打开oud
4、执行命令:unload dict
5、执行命令:scan extent (需等一会儿时间)
6、执行命令:desc [用户名].[被删除数据的表名]
Object ID:33547
  Storage(Obj#=33547 DataObj#=33549 TS#=11 File#=10 Block#=1400 Cluster=0)
  NO. SEG INT Column Name Null? Type
  --- --- --- ------------------------------ --------- ------------------------------
  1 1 1 OWNER VARCHAR2(30)
  2 2 2 OBJECT_NAME VARCHAR2(128)
  3 3 3 SUBOBJECT_NAME VARCHAR2(30)
  4 4 4 OBJECT_ID NUMBER
  5 5 5 DATA_OBJECT_ID NUMBER
  6 6 6 OBJECT_TYPE VARCHAR2(18)
  7 7 7 CREATED DATE
  8 8 8 LAST_DDL_TIME DATE
  9 9 9 TIMESTAMP VARCHAR2(19)
  10 10 10 STATUS VARCHAR2(7)
  11 11 11 TEMPORARY VARCHAR2(1)
  12 12 12 GENERATED VARCHAR2(1)
  13 13 13 SECONDARY VARCHAR2(1)
从上面的输出中,我们可以看到,TEST.T1表所在的表空间号为11,数据段头部为10号文件的1400号块。
  我们使用ODU来确定T1表原来的data object id。一般来说,数据段的数据块,一般是在段头后面相邻的块中。但是我们可以从段头来确认:
  ODU> dump datafile 10 block 1400
  Block Header:
  block type=0×23 (ASSM segment header block)
  block format=0×02 (oracle 8 or 9)
  block rdba=0×02800578 (file#=10, block#=1400)
  scn=0×0000.00286f2d, seq=4, tail=0×6f2d2304
  block checksum value=0×0=0, flag=0
  Data Segment Header:
  Extent Control Header
  -------------------------------------------------------------
  Extent Header:: extents: 1 blocks: 5
  last map: 0×00000000 #maps: 0 offset: 668
  Highwater:: 0×02800579 (rfile#=10,block#=1401)
  ext#: 0 blk#: 3 ext size:5
  #blocks in seg. hdr’s freelists: 0
  #blocks below: 0
  mapblk: 0×00000000 offset: 0
  --------------------------------------------------------
  Low HighWater Mark :
  Highwater:: 0×02800579 ext#: 0 blk#: 3 ext size: 5
  #blocks in seg. hdr’s freelists: 0
  #blocks below: 0
  mapblk 0×00000000 offset: 0
  Level 1 BMB for High HWM block: 0×02800576
  Level 1 BMB for Low HWM block: 0×02800576
  --------------------------------------------------------
  Segment Type: 1 nl2: 1 blksz: 2048 fbsz: 0
  L2 Array start offset: 0×00000434
  First Level 3 BMB: 0×00000000
  L2 Hint for inserts: 0×02800577
  Last Level 1 BMB: 0×02800576
  Last Level 1I BMB: 0×02800577
  Last Level 1II BMB: 0×00000000
  Map Header:: next 0×00000000 #extents: 1 obj#: 33549 flag: 0×220000000
  Extent Map
  -------------------------------------------------------------
  0×02800576 length: 5
  Auxillary Map
  -------------------------------------------------------------
  Extent 0 : L1 dba: 0×02800576 Data dba: 0×02800579
  -------------------------------------------------------------
  Second Level Bitmap block DBAs
  -------------------------------------------------------------
  DBA 1: 0×02800577
  从上面的输出中的“Extent 0 : L1 dba: 0×02800576 Data dba: 0×02800579”可以看到,段的第1个数据块的RDBA为0×02800579,也就是10号文件的1401块。
  我们dump第10号文件的1401块头,来得到表T1原来的data object id:
  ODU> dump datafile 10 block 1401 header
  Block Header:
  block type=0×06 (table/index/cluster segment data block)
  block format=0×02 (oracle 8 or 9)
  block rdba=0×02800579 (file#=10, block#=1401)
  scn=0×0000.00285f2b, seq=2, tail=0×5f2b0602
  block checksum value=0×0=0, flag=0
  Data Block Header Dump:
  Object id on Block? Y
  seg/obj: 0×830b=33547 csc: 0×00.285f21 itc: 3 flg: E typ: 1 (data)
  brn: 0 bdba: 0×2800576 ver: 0×01
  Itl Xid Uba Flag Lck Scn/Fsc
  0×01 0xffff.000.00000000 0×00000000.0000.00 C--- 0 scn 0×0000.00285f21
  0×02 0×0000.000.00000000 0×00000000.0000.00 ---- 0 fsc 0×0000.00000000
  0×03 0×0000.000.00000000 0×00000000.0000.00 ---- 0 fsc 0×0000.00000000
  Data Block Dump:
  ================
  flag=0×0 --------
  ntab=1
  nrow=16
  frre=-1
  fsbo=0×32
  ffeo=0×145
  avsp=0×113
  tosp=0×113
  可以看到,T1表原来的data object id就是33547。
 7. 使用ODU来unload数据:
  ODU> unload table test.t1 object 33547
   8、使用sqlldr导入我们恢复的数据:打开cmd命令,执行E:\ODU\data>sqlldr 用户名/密码@数据库id control=TEST_T1.ctl
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-251110-1-1.html 上篇帖子: oracle中truncate table后的数据恢复 下篇帖子: Oracle 数据库信息基础查询
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表