问:最近我们的服务器宕机了,WINNT4上安装了Oracle 8i数据库。我们已经获取了ORADATA目录,如下图所示: 点击放大 现在切换到新的服务器了,使用的是Windows 2003 Server和Oracle 9i的组合。我们创建了新的数据库,所以将所有的文件从之前的8i目录拷贝过来,数据库已经安装好,现在需要做的是更改控制文件的参数,将F盘变更为C盘。我先使用了更改数据库文件命名的命令:select name from V$datafile;,所有的文件都显示了正确的路径。
而当我使用更改数据库打开命令的时候,出现了下面的错误提示: 当文件重命名之后,文件数据也变更了,那……
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属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、获得备份
建议,在进行上述操作过程之前,再进行一个完整备份,有备无患。
作者
Techtarget旗下Searchoracle网站的资深专家,有16年IT行业经验、计算机科学硕士、专攻数据库方向,曾担任系统管理员等职。此外,他还获Oracle 7.3、8和8i的OCP数据库管理员证书,目前为SGT Inc.公司首席DBA。
翻译
相关推荐
-
DBA支招:如何实现Oracle EBS 12.2.5升级
那些对于是否要将EBS进行升级持观望态度的Oracle数据库管理员们可以从一家研究公司获得一些启示。
-
Oracle数据库云服务:处理各种规模的应用程序
Oracle表示将通过在未来六个月内开放三个新的数据中心或云可用性区域来支持其整体云产品。
-
Oracle 12c升级需遵循的简单步骤
现在是将Oracle数据库升级到12c版本的时间,DBA Brian Peasland说。通过Oracle数据库升级助手中的命令行很容易做到。
-
Oracle12c R2:利用分片技术提升分布式性能
在云环境中提升数据扩展性对Oracle来说非常重要,因为Oracle在从内部构建环境迁移到云环境的过程中会承担更多负载,同时会要求成本更低。