Oracle 回滚段表空间文件丢失的处理

来源:百度知道 编辑:UC知道 时间:2024/05/27 16:52:19

如果你检测到丢失或损坏了回滚段表空间的数据文件,并且数据库是运行着的,不要把它 down 掉。在很多情况下,数据库是启着的比关闭着解决问题更容易些。

这种情况的两种可能的解决方法:

(A) 使丢失的那个数据文件 offline, 并从备份中恢复它,这种情况适用于数据库是处于归档方式的。

(B)另一个方法是 offline 掉所有的那个文件所属表空间的回滚段, drop 那个表空间 , 然后得建它们。你可能不得不杀掉那些使用着回滚段的进程,以便使它 offline.

方法A: 从备份恢复那个数据文件

这个方法只有你的库是在归档方式下才能使用。

1 、脱机 (offline) 那个丢失的数据文件。 ALTER DATABASE DATAFILE OFFLINE;

提示:其于目前数据库的事务量,你可能需要建一个临时的回滚表空间和一些临时的回滚段以备正常业务运行。

2 、从备份中恢复 (restore) 那个数据文件。

3 、执行如下命令 SELECT V1.GROUP#, MEMBER, SEQUENCE#

FROM V$LOG V1, V$LOGFILE V2

WHERE V1.GROUP# = V2.GROUP# ;

这将列出所有的联机的重做日志和他们的序号及首次改变号 (first change numbers).

4 、得用联机日志及归档日志恢复那个文件 RECOVER DATAFILE

5 、确认所有的日志都被恢复,只到你收到 "Media recovery complete" 信息。

6 、使这个数据文件 online ALTER DATABASE DATAFILE ONLINE;

方法B: 重建回滚表空间

这种方法不必考虑数据库是否是归档模式的。

步骤如下:

1 、试图脱机所有的丢失或