oracle的dg迁移,三种ASM下将数据文件由dg迁移到dg的方法

应客户要求,需在ASM下将数据文件由dg迁移到dg,经过几天测试,有以下方法

一.

[root@darren ~]# su - grid

[grid@darren ~]$ asmcmd

ASMCMD> ls

DATA/

FRA/

ASMCMD> cd data/

ASMCMD> mkdir datafile

ASMCMD> ls

datafile/

SQL>ALTER DATABASE DATAFILE '+DATA/datafile/tbs_test_tablespac.dbf' OFFLINE;

ASMCMD>cp +data/datafile/tbs_test_tablespac.dbf +fra/datafile/tbs_test_tablespac.dbf

SQL>alter database rename file '+data/datafile/tbs_test_tablespac.dbf' to '+fra/datafile/tbs_test_tablespac.dbf';

SQL>RECOVER DATAFILE '+fra/datafile/tbs_test_tablespac.dbf';

SQL>alter database datafile '+fra/datafile/tbs_test_tablespac.dbf' online;

ALTER DISKGROUP DATA DROP FILE '+data/datafile/tbs_test_tablespac.dbf';

二.RMAN 下迁移

1.查出需要迁移的ASM数据文件,本次是需要迁移tbs_test_tablespac表空间下的文件。

SQL> select file_name,bytes/1024/1024/1024 ,tablespace_name from dba_data_files where tablespace_name ='tbs_test_tablespac';

3.将要迁移的 ASM 数据文件OFFLINE:

SQL> ALTER DATABASE DATAFILE '+DATA/datafile/tbs_test_tablespac.dbf' OFFLINE;

$ rman target /

RMAN> COPY DATAFILE '+data/datafile/tbs_test_tablespac.dbf' TO '+fra/datafile/tbs_test_tablespac.dbf';

SQL> ALTER DATABASE RENAME FILE '+data/datafile/tbs_test_tablespac.dbf' TO '+fra/datafile/tbs_test_tablespac.dbf';

RMAN> SWITCH DATAFILE '+fra/datafile/tbs_test_tablespac.dbf' TO COPY;

RMAN> RECOVER DATAFILE '+fra/datafile/tbs_test_tablespac.dbf';

SQL> ALTER DATABASE DATAFILE '+fra/datafile/tbs_test_tablespac.dbf' ONLINE;

SQL> SELECT file_name FROM dba_data_files;

SQL> ALTER DISKGROUP DATA DROP FILE '+data/datafile/tbs_test_tablespac.dbf';

三.在线重定义表到新表空间:

1.创建新表空间

sql>create bigfile tablespace tbs_test_tablespac_2 datafile '+fra/datafile/tbs_test_tablespac.dbf' size 100M autoextend off;

1)验证是否可以基于主键方式迁移

SQL>exec dbms_redefinition.can_redef_table(uname=>'test',tname=>'table_test',options_flag=>dbms_redefinition.cons_use_pk);

alter table test.table_test add  constraint table_test_pk primary key  (table_name) enable validate;

2)创建在线重定义中间表

SQL>create table TABLE_TEST2 (******) tablespace TBS_IDL_BID_2;

select table_name,tablespace_name from dba_tables where owner ='TEST';

3)在线重定义表

SQL>exec dbms_redefinition.start_redef_table(uname=>'TEST',orig_table=>'TABLE_TEST',int_table=>'TABLE_TEST2');

手动同步

SQL>exec dbms_redefinition.sync_interim_table(uname=>'TEST',orig_table=>'TABLE_TEST',int_table=>'TABLE_TEST2');

完成重定义

exec dbms_redefinition.finish_redef_table(uname=>'TEST',orig_table=>'TABLE_TEST',int_table=>'TABLE_TEST2');

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29863023/viewspace-1733115/,如需转载,请注明出处,否则将追究法律责任。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值