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

Oracle RMAN还原时set newname文件名有空格报错的解决方法

解决方法

那么这些数据库数据文件名怎么多了一些空格呢? 由于恰好这台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
  • asp之家 网络编程 m.aspxhome.com