文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Oracle Drop表如何进行purge恢复ODU

2024-04-02 19:55

关注

这篇文章给大家介绍Oracle Drop表如何进行purge恢复ODU,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

Oracle Drop表(purge)恢复(ODU)

通过ODU恢复drop掉的表(purge)基本步骤如下

1:offline表所在表空间;

2:通过logminer挖出被drop表对应object_id

3:使用ODU工具将表数据抽到文件中;

4:使用sqlldr将数据加载到数据库;

5:验证;

一:主备测试数据              

1 创建测试表odu_test

create table odu_test (a number,b varchar2(10),c nvarchar2(30),d varchar2(20),e date,f timestamp,g binary_float,h binary_double);

2 插入测试数据

insert into odu_test

  select rownum,

         lpad('x', 10),

         'NC测试' || rownum,

         'ZHS测试' || rownum,

         sysdate + dbms_random.value(0, 100),

         systimestamp + dbms_random.value(0, 100),

         rownum + dbms_random.value(0, 10000),

         rownum + dbms_random.value(0, 10000)

    from dba_objects

   where rownum <= 10000;

commit;

3 备份并删除表odu_test,模拟误删除

create table odu1 as select * from odu_test;

drop table odu_test purge;

二:恢复

1 offline表所在表空间

alter tablespace users offline;

2 使用logminer来查找被drop表的object_id

select group#,status from v$log;

select member from v$logfile where group#=1;

SQL> exec sys.dbms_logmnr.start_logmnr(options=>sys.dbms_logmnr.dict_from_online_catalog);

SQL> select scn,timestamp,sql_redo from v$logmnr_contents where operation='DDL' and sql_redo like '%odu_test%' order by 2 ;

......

    990001 2017/12/27  drop table odu_test purge;

SQL> select scn,timestamp,sql_redo from v$logmnr_contents where timestamp=to_date('2017-12-27','yyyy-mm-dd') order by 1;

SQL> create table logmnr_1 as (select * from  v$logmnr_contents;

SQL> exec sys.dbms_logmnr.end_logmnr;

select *from sys.logmnr_1 where scn='990001';  ---DATA_OB# 87270

select * from sys.logmnr_1 where LOWER(sql_redo) like '%odu_test%' order by 2 ;

3 修改原control.txt文件

select d.TS#        ts,

       d.FILE#      fno,

       d.FILE#      fno,

       d.NAME       filename,

       d.BLOCK_SIZE block_size

  from v$datafile d

 order by ts;

0    1    1    D:\APP\ADMINISTRATOR\ORADATA\CJC\SYSTEM01.DBF  8192

1    2    2    D:\APP\ADMINISTRATOR\ORADATA\CJC\SYSAUX01.DBF  8192

2    3    3    D:\APP\ADMINISTRATOR\ORADATA\CJC\UNDOTBS01.DBF 8192

4    4    4    D:\APP\ADMINISTRATOR\ORADATA\CJC\USERS01.DBF   8192

---control.txt

Oracle Drop表如何进行purge恢复ODU

4 登录odu

Oracle Drop表如何进行purge恢复ODU

Oracle Drop表如何进行purge恢复ODU

5 扫描数据

Oracle Drop表如何进行purge恢复ODU

---企业版ODU需要授权

Oracle Drop表如何进行purge恢复ODU

---本次实验使用测试版ODU

6 恢复表

Oracle Drop表如何进行purge恢复ODU

Oracle Drop表如何进行purge恢复ODU

......

Oracle Drop表如何进行purge恢复ODU

生成创建表的语句和控制文件

Oracle Drop表如何进行purge恢复ODU

这个命令生成了如下文件

ODU_0000087270.ctl和ODU_0000087270.sql

CREATE TABLE "ODU_0000087270"

(

    "C0001" NUMBER ,

    "C0002" VARCHAR2(4000) ,

    "C0003" NVARCHAR2(2000) ,

    "C0004" VARCHAR2(4000) ,

    "C0005" DATE ,

    "C0006" DATE ,

    "C0007" BINARY_FLOAT ,

    "C0008" BINARY_DOUBLE

);

7 online表空间

alter tablespace users online;

8 通过sqlldr加载数据

Oracle Drop表如何进行purge恢复ODU

9 验证数据

select count(*) from ODU_0000087270;  ---10000

查看恢复后表数据

select * from ODU_0000087270;

Oracle Drop表如何进行purge恢复ODU

......

查看备份表数据

Oracle Drop表如何进行purge恢复ODU

关于Oracle Drop表如何进行purge恢复ODU就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯