数据库日志文件出错的恢复一例
2008-03-28 23:01
260 查看
[align=center]数据库故障一例的解决[/align]
2008年3月28日星期五
今天启动数据库时,发现数据库只能加载到MOUNT状态,通过查询v$database视图发现数据库是在MOUNT状态下,尝试使用
alter database open;
打开数据库,结果报出以下错误信息
查询视图v$log,查看发生错误的是否是当前日志
观察发现日志文件REDO01的STATUS列显示CURRENT,表明是当前日志。
决定利用until cancel恢复数据库
选择CANCEL,表示不使用归档日志。打开数据库,并用带resetlogs子句的命令让数据库打开时重置日志文件。
OK,数据库打开了,查询了一下表,一切都正常了……
注意:这个恢复方法一般情况下不要采用,因为该方法可能导致数据库的不一致,而且极容易丢失数据,建议恢复完成后做一次全数据库备份。
2008年3月28日星期五
今天启动数据库时,发现数据库只能加载到MOUNT状态,通过查询v$database视图发现数据库是在MOUNT状态下,尝试使用
alter database open;
打开数据库,结果报出以下错误信息
SQL*Plus: Release 10.2.0.1.0 - Production on 星期五 3月 28 22:42:03 2008 Copyright (c) 1982, 2005, Oracle. All rights reserved. 请输入用户名: / as sysdba 连接到: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production With the Partitioning, OLAP and Data Mining options SQL> select open_mode from v$database; OPEN_MODE ---------- MOUNTED SQL> alter database open; alter database open * 第 1 行出现错误: ORA-16038: 日志 3 序列号 93 无法归档 ORA-19809: 超出了恢复文件数的限制 ORA-00312: 联机日志 3 线程 1: 'D:/ORACLE/ORADATA/MYORACLE/REDO03.LOG' |
SQL> select * from v$log; GROUP# THREAD# SEQUENCE# BYTES MEMBERS ARC STATUS ---------- ---------- ---------- ---------- ---------- --- ---------------- FIRST_CHANGE# FIRST_TIME ------------- -------------- 1 1 95 52428800 1 NO CURRENT 3719462 07-3月 -08 3 1 93 52428800 1 NO INACTIVE 3668109 07-3月 -08 2 1 94 52428800 1 NO INACTIVE 3692924 07-3月 -08 |
决定利用until cancel恢复数据库
SQL> recover database until cancel; 完成介质恢复。 SQL> alter database open resetlogs; 数据库已更改。 SQL> select * from scott.dept; DEPTNO DNAME LOC ---------- -------------- ------------- 10 ACCOUNTING NEW YORK 20 RESEARCH DALLAS 30 SALES CHICAGO 40 OPERATIONS BOSTON |
OK,数据库打开了,查询了一下表,一切都正常了……
注意:这个恢复方法一般情况下不要采用,因为该方法可能导致数据库的不一致,而且极容易丢失数据,建议恢复完成后做一次全数据库备份。
相关文章推荐
- SQLServer2005 没有日志文件(*.ldf) 只有数据文件(*.mdf) 恢复数据库的方法
- 数据库日志文件丢失时的恢复步骤
- SQL SERVER 2008 只有数据文件,没有日志文件,恢复数据库步骤
- SQL2005 如何在没有日志文件的情况下如何恢复MDF数据库文件
- SQL2005 如何在没有日志文件的情况下如何恢复MDF数据库文件?
- 如何恢复没有日志文件的数据库的方法
- 恢复已删除日志文件的数据库
- 缺失重做日志文件的数据库恢复
- Sqlserver 通过日志文件恢复数据库
- 无日志文件恢复数据库方法两则(一)
- mssql无数据库日志文件恢复数据库的方法第1/2页
- SQL Server 2005数据库日志文件损坏的情况下如何恢复数据库
- 控制文件损坏或者丢失的Oracle 10g数据库恢复控制文件一例
- 数据库日志文件丢失时的恢复步骤
- 直接删除undo及temp表空间文件后的数据库恢复一例
- Sql Server 只有MDF文件恢复数据库的方法以及2008清除日志文件
- RMAN数据库恢复之恢复归档日志文件
- 失而复得——数据库日志文件丢失后的恢复
- SQL Server 2005数据库日志文件损坏的情况下如何恢复数据库
- 无数据库日志文件恢复数据库方法两则[转自www.sql2005.com.cn]