Converting Oracle Database from Linux to Windows using RMAN

来源:这里教程网 时间:2026-03-03 11:56:36 作者:

1.查出源端linux下DB的v$database.platform_id和v$database.platform_name select platform_id,platform_name from v$database 13   Linux x86 64-bit 查出目标端windows下DB的v$database.platform_id和v$database.platform_name select platform_id,platform_name from v$database 12  Microsoft Windows x86 64-bit 2、查询源端和目标的字节序号v$transprotable_platform.endian_format是否一致,一致才可以迁移 select * from v$transportable_platform where platform_id in (12,13) 3.源端linux下DB启动到open read only shutdown immediate; startup mount; alter database open read only; 4.源端linux执行如下 declare v_return boolean; begin v_return:=dbms_tdb.check_db('Microsoft Windows x86 64-bit'); end; / declare b boolean; begin b:=dbms_tdb.check_external; end; / 以上两个语句不报错就可以 5.源端linux下备份 rman>convert database transport script '/u02/backup/transport.sql' to platform 'Microsoft Windows x86 64-bit' db_file_name_convert='/u01/app/oracle/oradata/hyprd/','/u02/backup/'; --以上如果在convert database后面加上 new database 'XX' 表示对要转换的目标数据库的数据文件生成新的数据库名,个人实验中没有做这个动作,因为目标端也想用源端的数据库名 /u02/backup/transport.sql就是源端linux导出来的控制文件 /u01/app/oracle/oradata/hyprd/就是源端linux的数据库文件路径 /u02/backup/就是源端linux导出数据库文件的存放路径 Microsoft Windows x86 64-bit就是目标端windows的v$database.platform_name 6、源端linux下创建pfile(个人的实验过程中没有做这个动作,因为之前已经在目标端创建了一个和源端一样dbname的空数据库) create pfile='/u02/backup/pfile.ora' from spfile; 7.把linux源端所有/u02/backup/下所有文件拷贝到windows目标端的一个临时目录如e:\oracle\backup 8.windows目标端建立用于rman恢复的目录(个人的实验过程中没有做这个动作,因为之前已经在目标端创建了一个和源端一样dbname的空数据库) $ORACLE_BASE/admin/SID/adump $ORACLE_BASE/admin/SID/bdump $ORACLE_BASE/admin/SID/cdump $ORACLE_BASE/admin/SID/udump $ORACLE_BASE/fast_recovery_area $ORACLE_BASE/oradata/SID 9.把目标端windows中的e:\oracle\backup文件都移动到$ORACLE_BASE/oradata/SID/(个人实验过程中,还去先删除$ORACLE_BASE/oradata/SID/原来的空数据库文件) 10.把从linux下拷贝过来的pfile文件进行修改,指定相关文件的目录(个人的实验过程中没有做这个动作,因为之前已经在目标端创建了一个和源端一样dbname的空数据库) 目标端spfile或pfile的*.control_files路径文件不需要修改为/u02/backup/transport.sql /u02/backup/transport.sql是源端生成的控制文件,最后我们需要这个文件生成真正的控制文件(即目标端spfile或pfile的*.control_files值对应的文件) 11.把从linux下拷贝过来的controlfile文件即/u02/backup/transport.sql进行修改,指定参数文件路径,数据文件路径,redo log路径,tempfile路径 12.保证linux目标库shutdown情况下,sqlplus执行/u02/backup/transport.sql /u02/backup/ sqlplus / as sysdba SQL>startup nomount SQL>@transport.sql

相关推荐