当数据库的数据文件实际存放位置与控制文件中定义的数据文件的路径不一致时,我们经常通过ALTER DATABASE RENAME FILE ...... to ...... 来改变控制文件定义的路径。
如果数据文件比较多,人工去校验,容易出错,则可以使用switch database to copy。
switch database to copy所做的正是把数据库中所有的文件都做了上面的这个步骤的操作,相当于若干个ALTER DATABASE RENAME FILE, 其实就是重命名control file中的文件地址。
我们来看看现象的具体情况:
ASM上的数据文件信息:
ASMCMD [+data/mynas/datafile] > ls -l
Type Redund Striped Time Sys Name
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y DBADATA.276.952933931
DATAFILE UNPROT COARSE AUG 11 21:00:00 Y DBS_D_HANK.273.951774293
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y DBS_D_HANK.274.951774467
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y DBS_D_JINGYU.262.951608185
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y DBS_I_JINGYU.263.951608185
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y SYSAUX.257.951608183
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y SYSTEM.258.951608183
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y TEST.264.951608185
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y TEST2.260.951608185
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y UNDOTBS1.259.951608185
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y UNDOTBS2.261.951608185
DATAFILE UNPROT COARSE AUG 31 16:00:00 Y USERS.265.951608205
SQL> select name from v$datafile;
+DATA/mynas/datafile/system.256.919998779
+DATA/mynas/datafile/sysaux.257.919998781
+DATA/mynas/datafile/undotbs1.258.919998783
+DATA/mynas/datafile/users.259.919998789
+DATA/mynas/datafile/undotbs2.264.919999419
+DATA/mynas/datafile/dbs_d_jingyu.268.947072261
+DATA/mynas/datafile/dbs_i_jingyu.270.947072263
+DATA/mynas/datafile/test.271.947072293
+DATA/mynas/datafile/test2.272.947072883
+DATA/mynas/datafile/dbs_d_hank.273.951758265
+DATA/mynas/datafile/dbadata.275.952933837
可以看到,虽然路径是对的,但由于OMF特性,文件名字完全不一样。
我们可以把ASM上的文件都认为是数据文件的copy备份,完全可以使用RMAN的catalog start with手工将这些copy“备份”加进来,数据库会认为这些文件就只是数据文件的copy备份,然后直接switch database to copy就可以成功切换。
RMAN> catalog start with '+data/mynas/datafile';
RMAN> switch database to copy;
datafile 1 switched to datafile copy “+DATA/mynas/datafile/system.258.951608183”
datafile 2 switched to datafile copy “+DATA/mynas/datafile/sysaux.257.951608183”
datafile 3 switched to datafile copy “+DATA/mynas/datafile/undotbs1.259.951608185”
datafile 4 switched to datafile copy “+DATA/mynas/datafile/users.265.951608205”
datafile 5 switched to datafile copy “+DATA/mynas/datafile/undotbs2.261.951608185”
datafile 6 switched to datafile copy “+DATA/mynas/datafile/dbs_d_jingyu.262.951608185”
datafile 7 switched to datafile copy “+DATA/mynas/datafile/dbs_i_jingyu.263.951608185”
datafile 8 switched to datafile copy “+DATA/mynas/datafile/test.264.951608185”
datafile 9 switched to datafile copy “+DATA/mynas/datafile/test2.260.951608185”
datafile 10 switched to datafile copy “+DATA/mynas/datafile/dbs_d_hank.274.951774467”
datafile 11 switched to datafile copy “+DATA/mynas/datafile/dbadata.276.952933931”
可以看到,数据文件都已经成功切换到正确的文件上,这时就可以了,整个过程简单、高效、不容易出错。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




