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

Posted: 九月 6, 2011 in 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;

–恢复表空间

[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恢复之表空间和数据块介质的恢复方法就介绍到这里了,希望本次的介绍能够对您有所帮助.

发表评论

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / 更改 )

Twitter picture

You are commenting using your Twitter account. Log Out / 更改 )

Facebook photo

You are commenting using your Facebook account. Log Out / 更改 )

Google+ photo

You are commenting using your Google+ account. Log Out / 更改 )

Connecting to %s