由于服务器更换,或者硬盘损坏等问题,在有些场景下,我们需要对数据库进行迁移。
Oracle 数据库有多种备份方式,如果可以停机,建议最好使用冷备的方式,直接迁移数据文件,这样效率会比较高。
由于两台主机都是Windows server,为了方便直接使用复制文件的方式,由于特殊原因,迁移前的数据目录和迁移后的数据目录是不一致的。直接迁移数据后,启动会报如下错误:
sql>startup ORACLE例程已经启动。 TotalSystemGlobalArea1071333376bytes FixedSize1334380bytes VariableSize301990804bytes DatabaseBuffers754974720bytes RedoBuffers13033472bytes 数据库装载完毕。 ORA-01157:无法标识/锁定数据文件1-请参阅DBWR跟踪文件 ORA-01110:数据文件1:'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\SYSTEM01.DBF'
查看文件路径:
sql>selectnamefromv$controlfile;
NAME --------------------------------------------------------- F:\APP\ADMINISTRATOR\ORADATA\AGRISK\CONTROL01.CTL F:\APP\ADMINISTRATOR\ORADATA\AGRISK\CONTROL02.CTL F:\APP\ADMINISTRATOR\ORADATA\AGRISK\CONTROL03.CTL
sql>selectnamefromv$datafile;
NAME --------------------------------------------------------- D:\APP\ADMINISTRATOR\ORADATA\AGRISK\SYSTEM01.DBF D:\APP\ADMINISTRATOR\ORADATA\AGRISK\SYSAUX01.DBF D:\APP\ADMINISTRATOR\ORADATA\AGRISK\UNDOTBS01.DBF D:\APP\ADMINISTRATOR\ORADATA\AGRISK\USERS01.DBF D:\APP\ADMINISTRATOR\ORADATA\AGRISK\AGRISK.DBF
sql>selectnamefromv$tempfile;
NAME --------------------------------------------------------- D:\APP\ADMINISTRATOR\ORADATA\AGRISK\TEMP01.DBF D:\APP\ADMINISTRATOR\ORADATA\AGRISK\AGRISK_TEMP.DBF
sql>selectmemberfromv$logfile;
MEMBER --------------------------------------------------------- D:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO03.LOG D:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO02.LOG D:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO01.LOG
停止数据库:
sql>shutdownimmediate;
将原主机上oradata目录下实例的文件全部拷贝到迁移后的主机对应目录。然后在新的主机上以mount方式启动数据库实例:
sql>startupmount;
除了控制文件的路径是正常的,其他的文件路径都需要修改,将原来的错误路径D盘改为F盘:
sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\SYSTEM01.DBF'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\SYSTEM01.DBF'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\SYSAUX01.DBF'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\SYSAUX01.DBF'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\UNDOTBS01.DBF'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\UNDOTBS01.DBF'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\USERS01.DBF'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\USERS01.DBF'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\AGRISK.DBF'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\AGRISK.DBF'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\TEMP01.DBF'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\TEMP01.DBF'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\AGRISK_TEMP.DBF'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\AGRISK_TEMP.DBF'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO01.LOG'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO01.LOG'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO02.LOG'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO02.LOG'; 数据库已更改。 sql>alterdatabaserenamefile'D:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO03.LOG'to'F:\APP\ADMINISTRATOR\ORADATA\AGRISK\REDO03.LOG'; 数据库已更改。
sql>alterdatabaSEOpen; 数据库已更改。
重启数据库:
sql>shutdownimmediate; 数据库已经关闭。 已经卸载数据库。 ORACLE例程已经关闭。
sql>startup ORACLE例程已经启动。 TotalSystemGlobalArea1071333376bytes FixedSize1334380bytes VariableSize301990804bytes DatabaseBuffers754974720bytes RedoBuffers13033472bytes 数据库装载完毕。 数据库已经打开。
查看监听端口。如果没有配置netca网络监听端口,需要使用系统自带的Net Cofiguration Assistant进行配置。
原文链接:https://www.f2er.com/oracle/208277.html