Oracle数据库RMAN恢复之表空间和数据块介质的恢复

数据库 Oracle
本文我们主要介绍了Oracle数据库RMAN恢复之表空间和数据块介质的恢复方法,并以实际的示例对其加以说明,希望能够对您有所帮助。

之前我们介绍过:Oracle数据库RMAN恢复之数据文件的恢复详解,本文我们介绍一下Oracle数据库REMAN恢复之表空间数据块介质的恢复,接下来我们就开始介绍一下这部分内容,首先我们先介绍一下恢复非系统表空间的示例。

示例一:表空间的数据文件被误删除

open状态下删除表空间对应的所有数据文件。

在open状态下使用alter tablespace ... offline for recover 脱机表空间。

使用restore tablespace ...转储表空间所有的数据文件。

使用recover tablespace ...应用归档日志。

最后使用alter tablespace ... online使表空间联机。

--open状态下删除表空间对应的所有数据文件。   

[oracle@localhost ~]$ rm /oracle/10g/oracle/product/10.2.0/oradatabak/users01.dbf;  

--恢复表空间   

[oracle@localhost ~]$ rman target sys/oracle@oralife nocatalog     
RMAN> run {    
2> sql 'alter tablespace users offline for recover';    
3> restore tablespace users;    
4> recover tablespace users;    
5> sql 'alter tablespace users online';    
6> }   
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.

示例二:表空间的数据文件所在磁盘出现故障

open状态下删除表空间对应的所有数据文件。

在open状态下使用alter tablespace ... offline for recover 脱机表空间。

执行set newname为数据文件指定新的位置。

使用restore tablespace ...转储表空间所有的数据文件。

执行switch datafile改变控制文件中数据文件位置和名称。

使用recover tablespace ...应用归档日志。

最后使用alter tablespace ... online使表空间联机。

--open状态下删除表空间对应的所有数据文件。   

[oracle@localhost ~]$ rm /oracle/10g/oracle/product/10.2.0/oradatabak/users01.dbf;    
SQL> select * from t_user;    
select * from t_user    
*    
ERROR at line 1:    
ORA-00376: file 4 cannot be read at this time    
ORA-01110: data file 4:    
'/oracle/10g/oracle/product/10.2.0/oradatabak/users01.dbf'    
SQL> select file#,error from v$recover_file;    
FILE# ERROR    
---------- -----------------------------------------------------------------     
4 FILE NOT FOUND    
--恢复表空间     
[oracle@localhost ~]$ rman target sys/oracle@oralife nocatalog    
run {    
sql 'alter tablespace users offline for recover';    
set newname for datafile 4 to '$ORACLE_BASE/product/10.2.0/oradata/oralife/user01.dbf';    
restore tablespace users;    
switch datafile all;    
recover tablespace users;    
sql 'alter tablespace users online';    
}    
--已恢复     
SQL> select * from t_user;    
TEXT    
--------------------     
java_    
SQL> select name from v$datafile where file# = 4;    
NAME    
--------------------------------------------------------------------------------     
/oracle/10g/oracle/product/10.2.0/oradata/oralife/user01.dbf 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.

数据块介质恢复

如果数据文件部分数据块出现损坏,可以使用blockrecover 命令恢复损坏数据块。

如:

RMAN> blockrecover device type disk   
2>datafile 5 block 2,7,88; 
  • 1.
  • 2.

关于Oracle数据库RMAN恢复之表空间和数据块介质的恢复方法就介绍到这里了,希望本次的介绍能够对您有所帮助。

【编辑推荐】

  1. Oracle数据库PL/SQL快捷键设置详解
  2. Oracle数据库诊断工具RDA的安装与使用详解
  3. Oracle数据库GLOBAL_NAMES参数的详细研究
  4. Oracle数据库归档模式的切换及其相关操作详解
  5. Oracle 10g UNDO表空间过大导致磁盘空间不足的解决
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2011-08-23 11:09:36

Oraclerman恢复system表空间恢复

2011-08-29 16:41:14

OracleRMAN恢复数据文件的恢复

2011-08-30 09:35:10

OracleRMAN不完全恢复基于时间恢复

2011-08-30 09:50:22

OracleRMAN不完全恢复基于SCN恢复

2011-08-30 10:02:18

OracleRMAN不完全恢复基于日志序列号恢复

2010-03-31 10:39:40

RMANOracle

2009-05-15 13:43:30

Oracle数据块损坏数据块恢复

2009-10-23 15:30:17

Oracle表空间恢复

2011-03-25 10:26:34

Oracle数据库管理表空间

2011-03-24 17:21:42

Oracle数据库Redo故障

2011-05-11 13:25:57

Oracle数据库后备恢复

2011-02-28 13:31:17

Oracle数据库

2009-11-20 13:29:59

Oracle数据库恢复

2011-05-26 09:36:07

Oracle数据库Redo故障

2011-08-03 18:42:21

Oracle数据库重做日志

2009-11-18 09:39:06

Oracle介质恢复

2011-03-04 14:59:16

Raidoracle数据库

2011-04-12 15:44:08

Oracle数据库

2011-05-26 10:01:16

Oracle数据库ODU

2010-04-12 10:40:49

Oracle数据库
点赞
收藏

51CTO技术栈公众号