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

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-02 05:27 点击:

 示例一:表空间的数据文件被误删除
  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> }
  示例二:表空间的数据文件所在磁盘出现故障
  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
  数据块介质恢复
  如果数据文件部分数据块出现损坏,可以使用blockrecover 命令恢复损坏数据块.
  如:
  RMAN> blockrecover device type disk
  2>datafile 5 block 2,7,88;
  关于Oracle数据库RMAN恢复之表空间和数据块介质的恢复方法就介绍到这里了,希望本次的介绍能够对您有所帮助.

作者“oracle认证价值”

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • Table函数使用简介
    • Oracle数据库Constraint约束的常用操作及异常处理
    • Bulk Collect性能分析(zz)
    • export/import的使用
    • OCP043第十五讲 Database Security
    • ORACLE10gr2数据导入MySQL方案
    • oracle 让sys用户可以使用isqlplus
    • 在oracle数据库下使用iSQL*Plus DBA访问数据库
    • Oracle行列转换小结
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1