作者:大航 | 来源:互联网 | 2023-10-12 14:12
问:最近我们的服务器宕机了,WINNT4上安装了Oracle8i数据库。我们已经获取了ORADATA目录,如下图所示:点击放大现在切换到新的服务器了,使用的是Windows2003
问:最近我们的服务器宕机了,WINNT4上安装了Oracle 8i数据库。我们已经获取了ORADATA目录,如下图所示:
点击放大
现在切换到新的服务器了,使用的是Windows 2003 Server和Oracle 9i的组合。我们创建了新的数据库,所以将所有的文件从之前的8i目录拷贝过来,数据库已经安装好,现在需要做的是更改控制文件的参数,将F盘变更为C盘。我先使用了更改数据库文件命名的命令:select name from V$datafile;,所有的文件都显示了正确的路径。
而当我使用更改数据库打开命令的时候,出现了下面的错误提示:
当文件重命名之后,文件数据也变更了,那我该如何解决这个问题?
答:首先,安装Oracle 8i然后试图进行恢复。上一次我试着恢复和升级同时进行时就遇到了类似的问题。Oracle不允许我打开数据库,因为软件版本发生了错误,而且我还无法进行STARTUP UPGRADE,因为我需要进行恢复。所以,在我看来最好是使用相同版本的数据库来进行恢复,然后再进行升级。
你没有提到过数据库备份是如何创建的。是直接把硬盘卸下来?数据库是否正常关闭了?
你的数据库是否运行在归档模式下?如有数据库没有在此模式,那么你可能会无法对开启的数据库进行恢复。在这一模式下,我会创建一个脚本来重建控制文件(CREATE CONTROLFILE)。可以在SQL参考指南中查询这条语法,在CREATE CONTROLFILE命令中写入新的路径。然后按照下面的步骤来做:
1、STARTUP NOMOUNT
2、创建控制文件
3、ALTER DATABASE RECOVER USING BACKUP CONTROLFILE UNTIL CANCEL;
4、如有需要,可以使用归档redo日志来进行恢复。若果数据库崩溃,你可能还需要指定在线redo日志文件。
5、CANCEL
6、ALTER DATABASE OPEN RESETLOGS;
7、SHUTDOWN IMMEDIATE
8、获得备份
建议,在进行上述操作过程之前,再进行一个完整备份,有备无患。