现在进入oracle12c时代;普遍用的oracle版本为10g以上。在oracle10g之后提供了一个回收的机制。所以恢复drop表的数据以及表很容易。当然需要打开回收机制以及是归档模式。若表被drop table tablename purge;这个是闪回技术恢复不了的。现如今中国技术达人(laoxiong)提供了odu工具,让这成为现实。大家可以关注他的博客。在此感谢(laoxiong)的贡献。
 
     就在这几天,技术老大认为数据库有几张表没用(其实另外一个平台页面有用);叫平台的兄弟清理掉;(其实那几张表;总共也就100多条数据;清不清真的没关系,没什么影响)。清理还是drop table tablename purge。下午发现一个平台打不开。叫我恢复下数据。虽然有备份;但还是用下odu工具来恢复下。
 
     1. 先将表空间置于offline状态。      
     SQL> alter tablespace zdgame2 offline;
 
     Tablespace altered.

2. 然后需要使用logminer来查找被drop表的data object id:

SQL> select group#,status from v$log;
 
    GROUP# STATUS
---------- ----------------
         1 INACTIVE
         2 CURRENT
         3 INACTIVE
 
 
SQL> select member from v$logfile where group#=2;
 
MEMBER
--------------------------------------------------
/u01/app/oradata/ora11g/redo02.log         
 
 
 
SQL>  exec sys.dbms_logmnr.add_logfile(logfilename=>'/u01/app/oradata/ora11g/redo02.log'); 
 
PL/SQL procedure successfully completed.
 
 
SQL> exec sys.dbms_logmnr.start_logmnr(options=>sys.dbms_logmnr.dict_from_online_catalog);
 
PL/SQL procedure successfully completed.
 
 
SQL> select scn,to_char(timestamp,'yyyymmddhh24miss'),sql_redo from v$logmnr_contents where operation='DDL' and sql_redo like '%acct_module_role%' order by 2 
--在这里得到drop表的时间结点 --20151125113452
 
SQL> select scn,timestamp,sql_redo from v$logmnr_contents where timestamp=to_date('2015-11-25 11:34:52','yyyy-mm-dd hh24:mi:ss') order by 1;
 
1.0790E+12 25-NOV-15
delete from "SYS"."OBJ$" where "OBJ#" = '68199' and "DATAOBJ#" = '68199' and "OW
 
       SCN TIMESTAMP
---------- ---------
SQL_REDO
--------------------------------------------------------------------------------
NER#" = '62' and "NAME" = 'ACCT_MODULE_ROLE' and "NAMESPACE" = '1' and "SUBNAME"
 IS NULL and "TYPE#" = '2' and "CTIME" = TO_DATE('25-NOV-15', 'DD-MON-RR') and "
MTIME" = TO_DATE('25-NOV-15', 'DD-MON-RR') and "STIME" = TO_DATE('25-NOV-15', 'D
D-MON-RR') and "STATUS" = '1' and "REMOTEOWNER" IS NULL and "LINKNAME" IS NULL a
nd "FLAGS" = '0' and "OID$" IS NULL and "SPARE1" = '6' and "SPARE2" = '1' and "S
PARE3" = '62' and "SPARE4" IS NULL and "SPARE5" IS NULL and "SPARE6" IS NULL and
 ROWID = 'AAAAASAABAAAP25AAI'; 

从最后一个查询语句从可以看到 objectid 为:68199

 
下面用odu工具来恢复数据;上传软件到oracle服务器上。并解压
从oracle获取控制信息
     SQL> select ts#,file#,rfile#,name from v$datafile;
把查询结果贴到control.txt;
执行./odu
[oracle@***** odu]$ ./odu
 
Oracle Data Unloader:Release 3.0.8
 
Copyright (c) 2008,2009 XiongJun. All rights reserved.
 
 
loading default config.......
 
byte_order little
block_size  8192
db_timezone -7
client_timezone 8
data_path   data
charset_name ZHS16GBK
ncharset_name AL16UTF16
output_format text
lob_storage infile
clob_byte_order little
 
 
 
 
load control file 'config.txt' successful
loading default control file ......
 
 
 ts#   fn  rfn bsize   blocks bf offset filename
---- ---- ---- ----- -------- -- ------ --------------------------------------------
   0    1    1  8192    89600 N       0 /u01/app/oradata/ora11g/system01.dbf
   1    2    2  8192    76800 N       0 /u01/app/oradata/ora11g/sysaux01.dbf
   2    3    3  8192    76160 N       0 /u01/app/oradata/ora11g/undotbs01.dbf
   4    4    4  8192    14560 N       0 /u01/app/oradata/ora11g/users01.dbf
   5    5    5  8192  2621440 N       0 /data/oradata/ora11g/******.dbf
   6    6    6  8192  1310720 N       0 /data/oradata/ora11g/******.dbf
load control file 'control.txt' successful
loading dictionary data......
 
ODU> scan extent tablespace 5;
 
scan extent start: 2015-11-25 11:52:21
scanning extent...
scanning extent finished.
scan extent completed: 2015-11-25 11:52:27
 
ODU> unload object 68199 sample                       --68199是上面查出来的结果
 
Unloading Object,object ID: 68199,  Cluster: 0
output data is in file :  'data/ODU_0000068199.txt' 
 
Sample result:
  object id: 68199
  tablespace no: 5
  sampled 56 rows
  column count: 6
  column    1  type: NUMBER
  column    2  type: VARCHAR2
  column    3  type: VARCHAR2
  column    4  type: VARCHAR2
  column    5  type: NUMBER
  column    6  type: NUMBER
 
COMMAND: 
unload object 68199 tablespace 5 column NUMBER VARCHAR2 VARCHAR2 VARCHAR2 NUMBER NUMBER 
 
ODU> unload object 68199 tablespace 5 column NUMBER VARCHAR2 VARCHAR2 VARCHAR2 NUMBER NUMBER
 
Unloading Object,object ID: 68199,  Cluster: 0
56 rows unloaded
到data目录下看下是否恢复;数据都在。
[oracle@×××××× data]$ ll
total 20
-rw-r--r-- 1 oracle dba  366 Nov 25 11:54 ODU_0000068199.ctl           
-rw-r--r-- 1 oracle dba  184 Nov 25 11:54 ODU_0000068199.sql           --为建表语句       
-rw-r--r-- 1 oracle dba 7264 Nov 25 11:54 ODU_0000068199.txt           --恢复的数据
-rw-r--r-- 1 oracle dba  773 Nov 25 11:53 sample.txt
先建表,在用sqlldr恢复数据即可。最后把先将表空间置于online状态。alter tablespace zdgame2 online;

oracle-odu小试牛刀--恢复drop表的数据的更多相关文章

  1. Oracle 备份、恢复单表或多表数据步骤

    Oracle 备份.恢复单表或多表数据步骤,适用于 Oracle 8.9.10.        *备份单表或多表数据: exp user/password@server file=filefullpa ...

  2. oracle 批量更新之将一个表的数据批量更新至另一个表

      oracle 批量更新之将一个表的数据批量更新至另一个表 CreationTime--2018年7月3日17点38分 Author:Marydon Oracle 将一个表的指定字段的值更新至另一个 ...

  3. Oracle使用fy_recover_data恢复truncate删除的数据

    (一)truncate操作概述 在生产中,truncate是使用的多的命令,在使用不当的情况下,往往会造成表的数据全部丢失,恢复较为困难.对于truncate恢复,常见的有以下几种方法可以进行恢复: ...

  4. oracle RAC 11g sqlload 生产表导入数据(ORA-12899)

    背景:由于即将来临的双十一,业务部门(我司是做京东,天猫的短信服务),短信入库慢,需要DBA把数据库sqlload进数据库. 表结构如下: MRS VARCHAR2(100), STATUS VARC ...

  5. oracle批量修改多个表的数据

    方法一 写PL/SQL,开cursor declare  l_varID varchar2(20);  l_varSubName varchar2(30);  cursor mycur is sele ...

  6. mysql InnoDB通过.frm和.ibd恢复表和数据

    ibdata1是一个用来构建innodb系统表空间的文件,这个文件包含了innodb表的元数据.撤销记录.修改buffer和双写buffer.如果file-per-table选项打开的话,该文件则不一 ...

  7. 两种方法将oracle数据库中的一张表的数据导入到另外一个oracle数据库中

    oracle数据库实现一张表的数据导入到另外一个数据库的表中的方法有很多,在这介绍两个. 第一种,把oracle查询的数据导出为sql文件,执行sql文件里的insert语句,如下: 第一步,导出sq ...

  8. Oracle中恢复drop掉的表中的数据

    今天同事不小心把生产上的一张表直接drop掉了,没有做备份,哥们慌的一匹,来找我这个小白来帮忙解决,于是心血来潮简单总结一下. 其实在oralce中,用drop删掉一张表,其实不会真正的删除,只是把表 ...

  9. Oracle恢复drop误删除的表和建用户操作

    一.表的恢复 对误删的表,只要没有使用PURGE永久删除选项,那么从flash back区恢复回来希望是挺大的.一般步骤有: 1.从flash back里查询被删除的表 select * from r ...

随机推荐

  1. java 部署服务报:Bad version number in .class file

    问题原因:服务器jdk版本和class文件的版本不一致,一般是服务器的jdk版本低于class文件的编译版本 解决方案:修改服务器的jdk

  2. Xib文件的使用

  3. Hadoop学习(3)-- 安装1.x版本

    Hadoop有三种安装模式,分别为单机模式.伪分布式模式和完全分布式模式(集群模式).本文安装版本是hadoop-1.1.2,hadoop-2.x版本安装请参考:http://www.cnblogs. ...

  4. .net 调度器怎么实现心跳(socket除了他,没选择吧)

    自己写调度器,就要从tcp通信入手:心跳的实现除了使用socket,想不到其他任何方案. socket基本使用demo: Socket Client: static void Main(string[ ...

  5. Android图像处理之Bitmap类(zz)

    Bitmap是Android系统中的图像处理的最重要类之一.用它可以获取图像文件信息,进行图像剪切.旋转.缩放等操作,并可以指定格式保存图像文件.本文从应用的角度,着重介绍怎么用Bitmap来实现这些 ...

  6. 解决 linux [Fedora] 升级 导致VMware启动出现"before you can run vmware workstation, serveral modules must be complied and loaded into the runing kernel" 而无法卸载

    解决: 开机启动 进入 升级之前的内核系统 然后 执行卸载 VMware 命令 # vmware-uninstall You have gotten this message because you ...

  7. ACM常用算法及练习(2)

    ACM常用算法及练习 知识类型 重要度 容易度 应掌握度 典型题 其他           数据结构(5) 链表 ★★☆ ★★★ ★★☆     栈 stack ★★★ ★★★ ★★★ HLoj120 ...

  8. HDU 4822 Tri-war(LCA树上倍增)(2013 Asia Regional Changchun)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4822 Problem Description Three countries, Red, Yellow ...

  9. 经过本人 6 年.net 工作经验证明 .net 工资确实比 Java 低

    很久没有逛博客园了,很久没有出来吐槽了.怎么呢?生活压力大,就需要找地方吐槽. 排版不怎么好,文笔不怎么好,可以看出我不是雇佣的写手. 工作到今夏,已经有6个年头了,一直使用着.net技术,但是最近工 ...

  10. CSS3 Transform Matrix

    css3中的transform让我们操作变形变得很简单,诸如,translate–移动,scale–缩放,rotate–旋转,skew–斜切.这几个属性很方便,也很简单,但是其中matrix我们就不常 ...