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

日期: 2011-08-01 作者:Brian Peasland翻译:孙瑞 来源:TechTarget中国 英文

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

  而当我使用更改数据库打开命令的时候,出现了下面的错误提示:   当文件重命名之后,文件数据也变更了,那……

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

问:最近我们的服务器宕机了,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、获得备份

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

作者

Brian Peasland
Brian Peasland

Techtarget旗下Searchoracle网站的资深专家,有16年IT行业经验、计算机科学硕士、专攻数据库方向,曾担任系统管理员等职。此外,他还获Oracle 7.3、8和8i的OCP数据库管理员证书,目前为SGT Inc.公司首席DBA。

翻译

孙瑞
孙瑞

相关推荐