Converting Oracle Database from Linux to Windows using RMAN

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


请使用浏览器的分享功能分享到微信等