Oracle RMAN还原时set newname文件名有空格报错的解决方法
作者:潇湘隐者 时间:2024-01-23 18:11:31
前言
在做数据恢复时,偶尔会碰到需要对数据文件位置调整的案例,在这种情况下,可以在RMAN中使用SET NEWNAME命令。
在Oracle 11g之前,RMAN只支持SET NEWNAME FOR DATAFILE,在Oracle 11g中增加了SET NEWNAME FOR TEMPFILE/SET NEWNAME FOR TABLESPACE/SET NEWNAME FOR DATABASE的命令。
优先顺序如下:
1.SET NEWNAME FOR DATAFILE and SET NEWNAME FOR TEMPFILE
2.SET NEWNAME FOR TABLESPACE
3.SET NEWNAME FOR DATABASE
发现问题
今天遇到一个非常奇怪的现象,查看ORACLE数据库的一个文件,明明这个文件是存在的,但是使用ls -lrt 查看都显示这个文件不存在。很是纳闷! 后面发现在终端输入文件名后并使用tab键时,发现文件后其实是有空格(不可见字符)。
如下截图所示:
[oracle@ehvlnx02 ~]$ ls -lrt /u01/oradata/SCM2/system01.dbf
ls: /u01/oradata/SCM2/system01.dbf: No such file or directory
[oracle@ehvlnx02 ~]$ cd /u01/oradata/SCM2/
[oracle@ehvlnx02 SCM2]$ ls -lrt
total 5238456
-rw-r----- 1 oracle oinstall 48504832 Nov 8 19:24 users01.dbf
-rw-r----- 1 oracle oinstall 209715712 Nov 8 19:24 redo06.log
-rw-r----- 1 oracle oinstall 209715712 Nov 8 19:24 redo05.log
-rw-r----- 1 oracle oinstall 209715712 Nov 8 19:24 redo04.log
-rw-r----- 1 oracle oinstall 209715712 Nov 8 19:24 redo02_1.log
-rw-r----- 1 oracle oinstall 367009792 Nov 8 19:24 ppc_x01.dbf
-rw-r----- 1 oracle oinstall 786440192 Nov 8 20:04 sysaux01.dbf
-rw-r----- 1 oracle oinstall 2553290752 Nov 8 20:09 undotbs01.dbf
-rw-r----- 1 oracle oinstall 545267712 Nov 8 20:09 system01.dbf
-rw-r----- 1 oracle oinstall 209715712 Nov 8 20:14 redo01_1.log
-rw-r----- 1 oracle oinstall 9781248 Nov 8 20:17 control01.ctl
[oracle@ehvlnx02 SCM2]$ ls system01.dbf\ \ \ \ \ \ \ \ \ \
system01.dbf
[oracle@ehvlnx02 SCM2]$ ls system01.dbf*
system01.dbf
[oracle@ehvlnx02 SCM2]$
clip_image001
解决方法
那么这些数据库数据文件名怎么多了一些空格呢? 由于恰好这台UAT服务器,我几小时前做过RMAN还原,发现然来使用set newname for datafile 后面指定路径和文件名时,双引号之间有大量空格(使用UE的列模式编写的还原命令),第一次遇到这种情况,看来以后使用set newname时,新的文件名要注意不能出现空格。否则就会出现这个情况。
run {
sql'alter session set nls_date_format="yyyy-mm-dd hh24:mi:ss"';
set until time '2017-11-08 03:30:00';
set newname for datafile 1 to "/u01/oradata/SCM2/system01.dbf ";
set newname for datafile 2 to "/u01/oradata/SCM2/undotbs01.dbf ";
set newname for datafile 3 to "/u04/oradata/SCM2/undotbs02.dbf ";
set newname for datafile 4 to "/u01/oradata/SCM2/sysaux01.dbf ";
set newname for datafile 5 to "/u01/oradata/SCM2/users01.dbf ";
.............................................................
restore database;
switch datafile all;
recover database;
}
来源:http://www.cnblogs.com/kerrycode/p/7804499.html
标签:oracle,rman,newname文件名
0
投稿
猜你喜欢
HTTP状态码
2009-09-21 12:46:00
Python 分形算法代码详解
2023-05-28 04:18:51
Python Unittest ddt数据驱动的实现
2023-10-29 14:54:14
asp将table生成excel文件(xls)
2011-03-07 11:17:00
SQL Server 2005 Express 安装失败解决办法
2024-01-17 13:50:39
mysql创建表设置表主键id从1开始自增的解决方案
2024-01-18 13:52:53
解决idea git切换多个分支后maven不生效的问题
2023-06-28 17:48:13
JavaScript中的eval()函数详解
2024-04-19 09:59:53
JavaScript中的函数声明和函数表达式区别浅析
2023-08-05 23:22:36
让ASP组件来保护你的网站,自定义加密方法的使用
2009-11-07 19:27:00
python检查字符串是否是正确ISBN的方法
2022-05-10 14:54:01
python程序快速缩进多行代码方法总结
2022-12-06 03:30:38
怎样开启phpStudy服务器
2023-05-25 00:38:06
Python实现数通设备端口使用情况监控实例
2021-02-09 23:56:41
python如何使用jt400.jar包代码实例
2021-05-07 03:50:46
python shell命令行中import多层目录下的模块操作
2023-08-24 11:28:40
Python中的Nonetype类型怎么判断
2021-06-19 17:33:13
pycharm下pyqt4安装及环境配置的教程
2021-11-01 16:03:57
HTTP长连接与短连接使用方法及测试详解
2023-05-08 16:15:25
详细讲解MySQL数据库对文件操作的封装
2008-12-17 16:08:00