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 /*operation='DDL' and*/ LOWER(sql_redo) like '%odu_test%' order by 2 ;
/*
delete from "SYS"."OBJ$" where "OBJ#" = '87270' and "DATAOBJ#" = '87270' and "OWNER#" = '84' and "NAME" = 'ODU_TEST' and "NAMESPACE" = '1' and "SUBNAME" IS NULL and "TYPE#" = '2' and "CTIME" = TO_DATE('27-12 月 -17', 'DD-MON-RR') and "MTIME" = TO_DATE('27-12 月 -17', 'DD-MON-RR') and "STIME" = TO_DATE('27-12 月 -17', 'DD-MON-RR') and "STATUS" = '1' and "REMOTEOWNER" IS NULL and "LINKNAME" IS NULL and "FLAGS" = '0' and "OID$" IS NULL and "SPARE1" = '6' and "SPARE2" = '1' and "SPARE3" = '84' and "SPARE4" IS NULL and "SPARE5" IS NULL and "SPARE6" IS NULL and ROWID = 'AAAAASAABAAAVKkABB';
*/
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
4 登入 odu
5 掃描資料
--- 企業版 ODU 需要授權
--- 本次實驗使用測試版 ODU
6 恢復表
......
生成建立表的語句和控制檔案
這個命令生成了如下檔案
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 載入資料
9 驗證資料
select count(*) from ODU_0000087270; ---10000
檢視恢復後表資料
select * from ODU_0000087270;
......
檢視備份表資料
......
原文連結如下:
歡迎關注我的微信公眾號"IT小Chen",共同學習,共同成長!!!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29785807/viewspace-2149476/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle Delete表恢復(ODU)Oracledelete
- Oracle Truncate表恢復(ODU)Oracle
- oracle drop table purge無備份bbed恢復(1/3)Oracle
- oracle drop table purge無備份bbed恢復(2/3)Oracle
- oracle drop table purge無備份bbed恢復(3/3)Oracle
- 使用ODU恢復oracle被truncate的表資料Oracle
- 恢復oracle中drop掉的表Oracle
- mysql恢復drop表MySql
- 使用ODU恢復被truncate表的資料
- oracle恢復表delete/truncate/drop的方法總結Oracledelete
- Oracle中truncate table後的資料恢復(Oracle資料恢復工具-ODU)Oracle資料恢復
- Oracle Purge和drop的區別Oracle
- Oracle 10g 中誤刪除(drop)表的恢復處理Oracle 10g
- oracle誤drop/update資料恢復測試Oracle資料恢復
- MySQL中使用undrop來恢復drop的表(上)MySql
- Oracle drop分割槽表單個分割槽無法透過閃回恢復Oracle
- 循序漸進oracle第8章:Oracle的閃回特性之恢復drop表四種方法Oracle
- RMAN恢復單個表空間或被DROP/DELETE/TRUNCATE的表delete
- 備份恢復軟體之dul、odu、aul介紹
- mysql 無備份恢復drop資料-共享表空間MySql
- db2 恢復drop後的表的一個操作DB2
- DROP TABLE ** CASCADE CONSTRAINTS PURGEAI
- Oracle RMAN 表空間恢復Oracle
- oracle12c表恢復Oracle
- ORACLE—DELETE表後的恢復Oracledelete
- Oracle10g 回收站及徹底刪除table : drop table xx purge 以及drop flashOracle
- 【Oracle 恢復表空間】 實驗Oracle
- 恢復Oracle表空間的方法Oracle
- Oracle 11g RMAN恢復-只讀表空間的恢復Oracle
- oracle 誤刪表 drop tableOracle
- Oracle恢復誤操作刪除掉的表Oracle
- Oracle RMAN 表空間的完全恢復Oracle
- Oracle 表級的快速恢復(實習)Oracle
- Oracle Recyclebin - purgeOracle
- 使用logmnr分析歸檔日誌恢復被drop掉的資料表
- Oracle 12C新特性-RMAN恢復表Oracle
- Oracle 12C 新特性之 恢復表Oracle
- oracle資料庫災難挽救應急方案之DDL誤操作恢復(drop)Oracle資料庫