Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2885824
  • 博文数量: 599
  • 博客积分: 16398
  • 博客等级: 上将
  • 技术积分: 6875
  • 用 户 组: 普通用户
  • 注册时间: 2009-11-30 12:04
个人简介

WINDOWS下的程序员出身,偶尔也写一些linux平台下小程序, 后转行数据库行业,专注于ORACLE和DB2的运维和优化。 同时也是ios移动开发者。欢迎志同道合的朋友一起研究技术。 数据库技术交流群:58308065,23618606

文章分类

全部博文(599)

文章存档

2014年(12)

2013年(56)

2012年(199)

2011年(105)

2010年(128)

2009年(99)

分类: Oracle

2010-01-04 14:08:16

前面介绍了非归档模式下日志文件丢失的解决方法。
联机日志文件丢失解决方法(一)
http://blog.chinaunix.net/u3/107027/showart_2138803.html
联机日志文件丢失解决方法(二)
http://blog.chinaunix.net/u3/107027/showart_2138811.html
下面几篇文章介绍归档模式下的日志文件丢失的解决方法。
本篇介绍归档模式下非当前联机日志文件丢失的解决方法。
如果日志文件已经归档,这种情况下恢复日志文件和非归档模式下没什么差别,只需要重建日志文件即可。
如果日志文件还没有归档,这种情况下重建日志文件要带有UNARCHIVED关键字。注意这种情况下会造成归档的断点,需要做一次全备。

SQL> SELECT NAME,OPEN_MODE,LOG_MODE FROM V$DATABASE;
NAME      OPEN_MODE  LOG_MODE
--------- ---------- ------------
TOMSYAN   READ WRITE ARCHIVELOG

SQL> SELECT GROUP#,SEQUENCE#,STATUS,ARCHIVED FROM V$LOG;
    GROUP#  SEQUENCE# STATUS           ARC
---------- ---------- ---------------- ---
         1          2 INACTIVE         YES
         2          3 INACTIVE         YES
         3          4 CURRENT          NO
SQL> SELECT MEMBER FROM V$LOGFILE WHERE GROUP#=1;
MEMBER
--------------------------------------------------------------------------------
C:\ORACLE\PRODUCT\10.2.0\ORADATA\TOMSYAN\REDO01.LOG
SQL> SHUTDOWN IMMEDIATE
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> HOST DEL C:\ORACLE\PRODUCT\10.2.0\ORADATA\TOMSYAN\REDO01.LOG
SQL> STARTUP
ORACLE 例程已经启动。
Total System Global Area  612368384 bytes
Fixed Size                  1250428 bytes
Variable Size             247466884 bytes
Database Buffers          356515840 bytes
Redo Buffers                7135232 bytes
数据库装载完毕。
ORA-00313: 无法打开日志组 1 (用于线程 1) 的成员
ORA-00312: 联机日志 1 线程 1:
'C:\ORACLE\PRODUCT\10.2.0\ORADATA\TOMSYAN\REDO01.LOG'

SQL> SELECT GROUP#,SEQUENCE#,STATUS,ARCHIVED FROM V$LOG;
    GROUP#  SEQUENCE# STATUS           ARC
---------- ---------- ---------------- ---
         1          2 INACTIVE         YES
         3          4 CURRENT          NO
         2          3 INACTIVE         YES
 
SQL> ALTER DATABASE CLEAR LOGFILE GROUP 1;
 
数据库已更改。
 
如果此处的日志组1还没有归档,要用下面的语句重建日志文件
 
ALTER DATABASE CLEAR UNARCHIVED LOGFILE GROUP 1;
 
这种情况下,别忘了做一次全备。
 
SQL> ALTER DATABASE OPEN;
数据库已更改。
阅读(794) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~