程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle數據庫RMAN恢復之表空間和數據塊介質的恢復

Oracle數據庫RMAN恢復之表空間和數據塊介質的恢復

編輯:Oracle數據庫基礎

示例一:表空間的數據文件被誤刪除

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;  

--恢復表空間   

  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恢復之表空間和數據塊介質的恢復方法就介紹到這裡了,希望本次的介紹能夠對您有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved