一般情况下,是无法利用RESETLOGS操作之前的备份进行数据库的恢复的。但是在特定条件下利用RESETLOGS之前的备份进行恢复是可行的。
本文继续上一篇文章的讨论。由于利用RESETLOGS前的备份进行恢复是需要RESETLOGS操作以后的控制文件的,本文讨论在丢失控制文件时,利用RESETLOGS后备份的控制文件进行进行数据库的恢复。
前面的步骤和上篇文章完全一样,首先是构造出需要使用的RESETLOGS前的数据库备份。这里就不再重复描述。
SQL> ALTER DATABASE BACKUP CONTROLFILE TO 'F:ORACLEBACKUPTEST20060311CONTROL01.CTL';
数据库已更改。
SQL> SHUTDOWN ABORT
ORACLE 例程已经关闭。
SQL> HOST COPY F:ORACLEBACKUPTEST_BEF_RESETLOGS* F:ORACLEORADATATEST
SQL> HOST COPY F:ORACLEBACKUPTEST20060311*.CTL F:ORACLEORADATATEST
SQL> HOST COPY F:ORACLEORADATATESTCONTROL01.CTL F:ORACLEORADATATESTCONTROL02.CTL
SQL> HOST COPY F:ORACLEORADATATESTCONTROL01.CTL F:ORACLEORADATATESTCONTROL03.CTL
首先备份了当前的控制文件,然后模仿数据库崩溃,丢失所有数据文件和控制文件。于是利用RESETLOGS前备份的数据文件和RESETLOGS后备份的控制文件进行恢复。
SQL> STARTUP MOUNT
ORACLE 例程已经启动。
Total System Global Area 76619308 bytes
Fixed Size 454188 bytes
Variable Size 50331648 bytes
Database Buffers 25165824 bytes
Redo Buffers 667648 bytes
数据库装载完毕。
SQL> RECOVER DATABASE USING BACKUP CONTROLFILE
ORA-00279: 更改 46427582 (在 03/10/2006 23:33:18 生成) 对于线程 1 是必需的
ORA-00289: 建议: F:ORACLEORADATATESTARCHIVEARC00001.001
ORA-00280: 更改 46427582 对于线程 1 是按序列 # 1 进行的
指定日志: {<RET>=suggested | filename | AUTO | CANCEL}
AUTO
ORA-00279: 更改 46427774 (在 03/10/2006 23:35:35 生成) 对于线程 1 是必需的
ORA-00289: 建议: F:ORACLEORADATATESTARCHIVEARC00002.001
ORA-00280: 更改 46427774 对于线程 1 是按序列 # 2 进行的
ORA-00278: 此恢复不再需要日志文件 'F:ORACLEORADATATESTARCHIVEARC00001.001'
ORA-00279: 更改 46427790 (在 03/10/2006 23:35:53 生成) 对于线程 1 是必需的
ORA-00289: 建议: F:ORACLEORADATATESTARCHIVEARC00003.001
ORA-00280: 更改 46427790 对于线程 1 是按序列 # 3 进行的
ORA-00278: 此恢复不再需要日志文件 'F:ORACLEORADATATESTARCHIVEARC00002.001'
ORA-00279: 更改 46448728 (在 03/11/2006 09:40:43 生成) 对于线程 1 是必需的
ORA-00289: 建议: F:ORACLEORADATATESTARCHIVEARC00004.001
ORA-00280: 更改 46448728 对于线程 1 是按序列 # 4 进行的
ORA-00278: 此恢复不再需要日志文件 'F:ORACLEORADATATESTARCHIVEARC00003.001'
ORA-00328: 归档日志在更改 46075117 结束,需要稍后的更改 46448728
IXDBA.NET社区论坛
ORA-00334: 归档日志: 'F:ORACLEORADATATESTARCHIVEARC00004.001'
SQL> RECOVER DATABASE USING BACKUP CONTROLFILE
ORA-00279: 更改 46448728 (在 03/11/2006 09:40:43 生成) 对于线程 1 是必需的
ORA-00289: 建议: F:ORACLEORADATATESTARCHIVEARC00004.001
ORA-00280: 更改 46448728 对于线程 1 是按序列 # 4 进行的
指定日志: {<RET>=suggested | filename | AUTO | CANCEL}
F:ORACLEORADATATESTREDO02.LOG
已应用的日志。
完成介质恢复。
SQL> ALTER DATABASE OPEN RESETLOGS;
数据库已更改。
SQL> SELECT COUNT(*) FROM YANGTK.TEST_BACKUP;
COUNT(*)
----------
1
其实上面的步骤和上一篇文章后面介绍的差不多,需要注意的是在RECOVER DATABASE时指定USING BACKUP CONTROLFILE,且恢复过程中需要将恢复使用REDO.LOG名称提供给ORACLE,并且最后使用RESETLOGS方式打开。