Oracle数据库RMAN恢复之表空间和数据块介质的恢复_Oracle_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > Oracle > Oracle数据库RMAN恢复之表空间和数据块介质的恢复

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

 2013/8/10 1:20:03    程序员俱乐部  我要评论(0)
  • 摘要:之前我们介绍过:Oracle数据库RMAN恢复之数据文件的恢复详解,本文我们介绍一下Oracle数据库REMAN恢复之表空间和数据块介质的恢复,接下来我们就开始介绍一下这部分内容,首先我们先介绍一下恢复非系统表空间的示例。示例一:表空间的数据文件被误删除open状态下删除表空间对应的所有数据文件。在open状态下使用altertablespace...offlineforrecover脱机表空间。使用restoretablespace...转储表空间所有的数据文件
  • 标签:ORA 数据库 数据 Oracle Oracle数据库

之前我们介绍过: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;  

--恢复表空间   

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

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

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

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

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

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

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

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

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

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

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

数据块介质恢复

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

如:

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

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

发表评论
用户名: 匿名