热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Oracle数据库文件路径怎么改,在已修复的Oracle数据库中更改文件路径

问:最近我们的服务器宕机了,WINNT4上安装了Oracle8i数据库。我们已经获取了ORADATA目录,如下图所示:点击放大现在切换到新的服务器了,使用的是Windows2003

问:最近我们的服务器宕机了,WINNT4上安装了Oracle 8i数据库。我们已经获取了ORADATA目录,如下图所示:

《Oracle数据库文件路径怎么改,在已修复的Oracle数据库中更改文件路径》

点击放大

现在切换到新的服务器了,使用的是Windows 2003 Server和Oracle 9i的组合。我们创建了新的数据库,所以将所有的文件从之前的8i目录拷贝过来,数据库已经安装好,现在需要做的是更改控制文件的参数,将F盘变更为C盘。我先使用了更改数据库文件命名的命令:select name from V$datafile;,所有的文件都显示了正确的路径。

而当我使用更改数据库打开命令的时候,出现了下面的错误提示:

《Oracle数据库文件路径怎么改,在已修复的Oracle数据库中更改文件路径》

当文件重命名之后,文件数据也变更了,那我该如何解决这个问题?

答:首先,安装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、获得备份

建议,在进行上述操作过程之前,再进行一个完整备份,有备无患。


推荐阅读
author-avatar
大航
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有