Oracle 數據文件誤刪除的不完全恢復

應用環境: 我的一個表被人不小心誤刪除了,這時候,我不可以把整個庫都恢復回去,那樣太麻煩了。

所以現在我就從新到一個新庫,只將這一個數據文件拷貝過來恢復。


那我們Oracle在恢復文件的時候是不可以只恢復一部分數據文件的,因爲oracle  要保證數據文件塊頭信息一致,所以如果我們要恢復部分文件的話,就得采取以下這種方法:


可以另起一個庫,再把要恢復的數據文件拷貝過來,恢復。(當然不單單是該數據文件,還要包括system表空間,undo表空間)

1)另起一個庫很簡單,可以搞出參數文件,在參數文件中添加一行*.db_unique_name='rt'和修改控制文件路徑。

$ORACLE_SID=rt
sqlplus / as sysdba
>startup nomount pfile='/tmp/pfile.ora'

接着控制文件怎麼辦呢,

2)當然我們可以將之前備份的數據文件直接恢復到我們配置的參數文件中控制文件的路徑。

恢復控制文件:

rman target >  restore controlfile to '/u01/app/oracle/oradata/test/rt_con01.ctl' from '/tmp/FULL_04pe7jue_1_1.bak';


那現在可以mount了。

現在是不可以open的,如果你現在open,他就會把原來的logfile 覆蓋,那肯定原來的那個庫會出問題。

3)我們這裏要做的就是先恢復數據文件:

 在rman中用到一個newname,首先確定原來的system,undo,還有要恢復的表空間文件號。

run {
allocate channel di type disk;
set newname for datafile 1 to '/tmp/disk1/system01.dbf';
set newname for datafile 3 to '/tmp/disk1/undotbs01.dbf';
set newname for datafile 9 to '/tmp/disk1/test_01.dbf';
restore datafile 1,3,9;
}

當然你執行上面會報錯,因爲我們是新創建的控制文件,所以要註冊一下:

rman >catalog start with '/tmp/FULL_04pe7jue_1_1.bak'

4) 然後在主庫更改redo日誌:

select * from v$log;
    GROUP# THREAD# SEQUENCE# BYTES BLOCKSIZE MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIME NEXT_CHANGE#
---------- ---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ------------------- ------------
NEXT_TIME
-------------------
         1 1 75 52428800 512 2 YES INACTIVE 4215102 2014-07-26:22:18:25 4215195
2014-07-26:22:19:55
         2 1 74 52428800 512 2 YES INACTIVE 4211699 2014-07-26:20:55:55 4215102
2014-07-26:22:18:25
         3 1 76 52428800 512 2 NO CURRENT 4215195 2014-07-26:22:19:55 2.8147E+14

當前正在用的是group  3,那我們可以刪除group1;

SYS@_connect_identifier>alter database drop logfile group 1; 數據庫已更改。
SYS@_connect_identifier>alter database add logfile group 1('/u01/app/oracle/oradata/test/mredo01.log') size 60m reuse; 數據庫已更改。

跟着刪除group 2 :

SYS@_connect_identifier
>
alter database drop logfile group 2; 
數據庫已更改。 
SYS@_connect_identifier
>
alter database add logfile group 2('/u01/app/oracle/oradata/test/mredo02.log') size 60m reuse; 
數據庫已更改。

那3就要跟着切換日誌,做完全檢查點了:

SYS@_connect_identifier>select * from v$log;
 GROUP# THREAD# SEQUENCE# BYTES BLOCKSIZE MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIME NEXT_CHANGE# ---------- ---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ------------------- ------------ NEXT_TIME ------------------- 1 1 0 62914560 512 1 YES UNUSED 0 0 2 1 
 0 62914560 512 1 YES UNUSED 0 0 3 1 
 76 52428800 512 2 NO CURRENT 4215195 2014-07-26:22:19:55 2.8147E+14

 SYS@_connect_identifier>alter system switch logfile; 
系統已更改。 
SYS@_connect_identifier>alter system checkpoint; 
系統已更改。 
SYS@_connect_identifier>alter database drop logfile group 3; 
數據庫已更改。 
SYS@_connect_identifier>alter database add logfile group 3('/u01/app/oracle/oradata/test/mredo03.log')size 60m reuse;
 數據庫已更改。

將備庫中不用數據文件更改掉

alter database datafile 2 offline drop;

alter database datafile 4 offline drop;

alter database datafile 5 offline drop;

alter database datafile 6 offline drop;

alter database datafile 8 offline drop;

alter database datafile 10 offline drop;

6)備庫更改數據文件路徑和歸檔日誌文件路徑:

SYS@_connect_identifier>alter database rename file '/u01/app/oracle/oradata/test/system01.dbf' to '/tmp/disk1/system01.dbf' 2 ; 
數據庫已更改。 

SYS@_connect_identifier>alter database rename file '/u01/app/oracle/oradata/test/undotbs01.dbf' to '/tmp/disk1/undotbs01.dbf';
 數據庫已更改。 
 
 SYS@_connect_identifier>alter database rename file '/u01/app/oracle/oradata/test/test_01' to '/tmp/disk1/test_01.dbf'; 
 數據庫已更改。

 SYS@_connect_identifier>set LOGSOURCE '/tmp/disk1/arch';

7)恢復日誌文件

SYS@_connect_identifier
>recover database using BACKUP controlfile until cancel; 
ORA-00279: 更改 4203853 (在 07/24/2014 19:57:38 生成) 對於線程 1 是必需的 ORA-00289: 
建議: /tmp/disk1/arch/1_73_831746264.dbf 
ORA-00280: 更改 4203853 (用於線程 1) 在序列 #73 中

檢查數據文件路徑,日誌文件路徑:

SYS@_connect_identifier
>select * from v$dbfile; 
FILE# NAME 
---------- ---------------------------------------- 
10 /u01/app/oracle/oradata/test/rman01.dbf 
9 /tmp/disk1/test_01.dbf 
8 /tmp/perstat.ora 
6 /home/oracle/trans.dbf 
5 /u01/app/oracle/oradata/test/example01.d 
bf 
4 /u01/app/oracle/oradata/test/users01.dbf 
3 /tmp/disk1/undotbs01.dbf 
2 /u01/app/oracle/oradata/test/sysaux01.db 
f 
FILE# NAME 
---------- ---------------------------------------- 
1 /tmp/disk1/system01.dbf 
已選擇9行。

8)打開數據庫,任務結束:

SYS@_connect_identifier
>
alter database open resetlogs; 
數據庫已更改。 
SYS@_connect_identifier
>select * from v$log; 
GROUP# THREAD# SEQUENCE# BYTES BLOCKSIZE MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIME NEXT_CHANGE# 
---------- ---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ------------------- ------------ 
NEXT_TIME 
------------------- 
1 1 1 52428800 512 2 NO CURRENT 4203854 2014-07-27:12:39:11 2.8147E+14 
2 1 0 52428800 512 2 YES UNUSED 0 0 
3 1 0 52428800 512 2 YES UNUSED 0 0 
SYS@_connect_identifier
>


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章