应客户要求,需在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/,如需转载,请注明出处,否则将追究法律责任。