舊數據文件,舊控制文件,新日志,怎樣恢復?
2024-07-21 02:36:40
供稿:網友
步驟:
1:修改trc文件(或者編寫)你的create control file 的腳本(或sql語句)
類似下面的,例如,保存到aaa.sql:
CREATE CONTROLFILE REUSE DATABASE "SCP" NORESETLOGS ARCHIVELOGARCHIVELOG
MAXLOGFILES 64
MAXLOGMEMBERS 2
MAXDATAFILES 254
MAXINSTANCES 32
MAXLOGHISTORY 113
LOGFILE
GROUP 1 '/home/Oracle/recovery5/redo01.dbf' SIZE 130000K,
GROUP 2 '/home/oracle/recovery5/redo02.dbf' SIZE 130000K,
GROUP 3 '/home/oracle/recovery5/redo03.dbf' SIZE 130000K,
GROUP 4 '/home/oracle/recovery5/redo04.dbf' SIZE 130000K,
GROUP 5 '/home/oracle/recovery5/redo05.dbf' SIZE 130000K,
GROUP 6 '/home/oracle/recovery5/redo06.dbf' SIZE 130000K
DATAFILE
'/home/oracle/recovery5/SYSTEM_drd3',
'/home/oracle/recovery5/TOOLS_drd4',
'/home/oracle/recovery5/RBS_drd6',
'/home/oracle/recovery5/TEMP_drd5',
'/home/oracle/recovery5/USERS_drd13',
'/home/oracle/recovery5/INDX_drd12'
CHARACTER SET US7ASCII
;
2:用你的有效備份覆蓋現在的錯誤數據文件
3:重建控制文件,就是前面的帖子的步驟
sqlplus internal或者sqlplus /nolog ; conn / as sysdba
startup nomount
@aaa.sql
4:用控制文件恢復數據庫
shutdown
startup mount
recover using backup controlfile until cancel;
直到所有的archive log file都用完了,alter database open resetlogs;
5:resetlogs open db
注重!假如你的archive 和init中定義的不一致,系統會提示你輸入: Specify log: {=suggested filename AUTO CANCEL}你可以輸入auto,也可以指定你的archive log files的路徑和名稱,或者你也可以用類似下面的命令:
recover automatic from '/home/oracle/recovery/arch' using backup controlfile until cancel;
(2)丟失所有數據文件,控制文件,redo日志文件 (續1)
成功恢復過程:
1. 拷貝舊冷備數據文件
rcp -r 冷備 數據目錄
2. mount數據庫
Oracle_home>bin/svrmgrl
SVRMGR> connect internal
SVRMGR> startup mount
3. 用using backup controlfile進行恢復
SVRMGR> recover database until cancel using backup controlfile;
出現輸入提示時輸入AUTO
4. 用Open Resetlog 打開數據庫
SVRMGR> alter database open RESETLOGS;
5. 恢復結束,看一下目前日志狀態
SVRMGR> archive log list;
應出現:
Oldest online log sequence 0
Next log sequence to archive 1
Current log sequence 1
其恢復過程如下,
丟失所有數據文件,控制文件,redo日志文件
成功恢復過程:
1. 拷貝舊冷備數據文件
rcp -r 冷備 數據目錄
2. mount數據庫
Oracle_home>bin/svrmgrl
SVRMGR> connect internal
SVRMGR> startup mount
3. 用using backup controlfile進行恢復
SVRMGR> recover database until cancel using backup controlfile;
出現輸入提示時輸入AUTO
4. 用Open Resetlog 打開數據庫
SVRMGR> alter database open RESETLOGS;
5. 恢復結束,看一下目前日志狀態
SVRMGR> archive log list;
應出現:
Oldest online log sequence 0
Next log sequence to archive 1
Current log sequence 1