(转载)数据库出现ORA-00283/ORA-01610的问题

在这里需要感谢棉花糖给予无私帮助,真的谢谢他!
http://blog.itpub.net/67668/viewspace-353270/
处理过程可以参照http://www.itpub.net/viewthread.php?tid=1010027&extra=&page=1

下面我把问题的处理做一个小的总结,希望有所帮助
问题主要是:resetlogs/noresetlogs与控制文件方面的(参照eygle的书)
第一:
要弄清楚resetlogs与noresetlogs的区别
norestlogs,控制文件的scn是来自当前日志的high scn,而resetlogs控制文件的scn是来自数据文件。
我在这里开始没有弄明白,我以noresetlogs进行恢复没有问题,后来请教了棉花糖才知道为什么noresetlogs可以成功,而resetlogs没有成功。

第二:
如何时取得创建控制文件的脚本,方法如下:
sql>alter database backup to trace;
然后通过查询跟踪文件的脚本可以查询到相关的详细信息
SQL> SELECT a.VALUE||b.symbol||c.instance_name||‘_ora_‘||d.spid||‘.trc‘ TRACE_FILE_NAME
  2  FROM (SELECT VALUE FROM v$parameter WHERE NAME=‘user_dump_dest‘) a,
  3       (SELECT SUBSTR(VALUE,-6,1) symbol FROM v$parameter WHERE NAME=‘user_dump_dest‘) b,
  4       (SELECT instance_name FROM v$instance) c,
  5       (SELECT spid FROM v$session s,v$process p,v$mystat m
  6        WHERE s.paddr=p.addr AND s.SID=m.SID AND m.statistic#=0) d
  7  /

TRACE_FILE_NAME
---------------------------------------------------------------------------------------------
E:\ORACLE\PRODUCT\10.2.0\ADMIN\ORCL\UDUMP\orcl_ora_5724.trc
在这orcl_ora_5724.trc脚本中可以找到创建控制文件的两种方式noresetlogs/resetlogs.

第三:模拟出错的过程
shutdown abort来进行关闭据库。
第四:利用noresetlogs来进行控件文件以及数据库的恢复
1.启动到数据库为nomount状态
sql>startup nomount;
2.开始创建控制文件
CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS  ARCHIVELOG
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 100
    MAXINSTANCES 8
    MAXLOGHISTORY 292
LOGFILE
  GROUP 1 ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO01.LOG‘  SIZE 50M,
  GROUP 2 ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO02.LOG‘  SIZE 50M,
  GROUP 3 ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO03.LOG‘  SIZE 50M
-- STANDBY LOGFILE
DATAFILE
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\UNDOTBS01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSAUX01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\USERS01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\EXAMPLE01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\FTITEM10G01‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\EYGLE01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\FTTEST01‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\USERS02.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\ZXF1.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\ZXF2.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\TZX01.DBF‘
CHARACTER SET ZHS16GBK
;
3.recover database; //恢复数据库
4.打开数据库 alter database open;
因为noresetlogs是用当前日志的high scn来恢复,所以基本没有问题。

第四:利用resetlogs来进行控件文件以及数据库的恢复,这里出现的一些问题
1.shutdown abort
2.数据库启动到nomount状态
3.创建控制文件
CREATE CONTROLFILE REUSE DATABASE "ORCL" RESETLOGS  ARCHIVELOG
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 100
    MAXINSTANCES 8
    MAXLOGHISTORY 292
LOGFILE
  GROUP 1 ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO01.LOG‘  SIZE 50M,
  GROUP 2 ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO02.LOG‘  SIZE 50M,
  GROUP 3 ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO03.LOG‘  SIZE 50M
-- STANDBY LOGFILE
DATAFILE
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\UNDOTBS01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSAUX01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\USERS01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\EXAMPLE01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\FTITEM10G01‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\EYGLE01.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\FTTEST01‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\USERS02.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\ZXF1.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\ZXF2.DBF‘,
  ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\TZX01.DBF‘
CHARACTER SET ZHS16GBK
;
4.alter database mount; 把数据库启动到mount状态
5.SQL> recover database;
   ORA-00283: 恢复会话因错误而取消
   ORA-01610: 使用 BACKUP CONTROLFILE 选项的恢复必须已完成
因为采用的resetlogs方式,所以会出现如上的错误
这时需要用如下的方式进行恢复
SQL> recover database using backup controlfile until cancel;
ORA-00279: 更改 6432534 (在 06/22/2008 16:39:31 生成) 对于线程 1 是必需的
ORA-00289: 建议:
E:\ORACLE\PRODUCT\10.2.0\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2008_06_22\O1_MF_1_
13_%U_.ARC
ORA-00280: 更改 6432534 (用于线程 1) 在序列 #13 中

指定日志: {=suggested | filename | AUTO | CANCEL}

在这里有几个选项
suggested:在上面ORA-00289: 建议:....会按这个文件去恢复
filename:自己指定日志文件
auto:自动选择,但我个人觉得好像和suggestted一样呢:(
cancel:这个可以不从介质恢复。

我在这里选择auto和suggested无不行,报的错误如下:
指定日志: {=suggested | filename | AUTO | CANCEL}
auto
ORA-00308: 无法打开归档日志 ‘E:ORACLEPRODUCT10.2.0FLASH_RECOVERY_AREAORCLARCHIVELOG2008_06_22
ORA-27041: 无法打开文件
OSD-04002: 无法打开文件
O/S-Error: (OS 2) 系统找不到指定的文件。

采用cancel报如下错:
ORA-01112: 未启动介质恢复

经过以上的步骤后来发现:
我这里的归档日志中要求的是日志文件不存在
指定日志: {=suggested | filename | AUTO | CANCEL}
E:ORACLEPRODUCT10.2.0FLASH_RECOVERY_AREAORCLARCHIVELOG2008_06_22O1_MF_1_9_45W1NQDP_.ARC
ORA-00310: 归档日志包含序列 9; 要求序列 10
ORA-00334: 归档日志:
‘E:ORACLEPRODUCT10.2.0FLASH_RECOVERY_AREAORCLARCHIVELOG2008_06_22O1_MF_1
_9_45W1NQDP_.ARC‘

查看日志文件:
select * from v$log;
GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS      
------ ---------- ---------- ---------- ---------- --- --------
     1          1          0   52428800          1 YES UNUSED
     3          1          0   52428800          1 YES CURRENT
     2          1          0   52428800          1 YES UNUSED
发现这里的理解有问题,因为采用的是resetlogs,所以日志文件肯定是unused的,呵, 这里要多谢棉花糖的。

6.仔细查看eygle的书这时有一句话
"如果在线日志未损坏,则可以指定在线日志文件执行恢复",这时棉花糖也指出了这点:
“哦,忘了你的是resetlogs,你的在线日志还在吧 ,把在线日志的路径输入啊,比如这样D:ORACLEPRODUCT10.2.0ORADATATESTREDO01.LOG ,你把所有的日志测试过去,有一个应该是能用来做恢复”
经过再次尝试终于成功了
SQL> recover database using backup controlfile until cancel;
ORA-00279: 更改 6432534 (在 06/22/2008 16:39:31 生成) 对于线程 1 是必需的
ORA-00289: 建议:
E:\ORACLE\PRODUCT\10.2.0\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2008_06_22\O1_MF_1_
13_%U_.ARC
ORA-00280: 更改 6432534 (用于线程 1) 在序列 #13 中

指定日志: {=suggested | filename | AUTO | CANCEL}
E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO03.LOG
ORA-00310: 归档日志包含序列 12; 要求序列 13
ORA-00334: 归档日志: ‘E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO03.LOG‘

SQL>  recover database using backup controlfile until cancel;
ORA-00279: 更改 6432534 (在 06/22/2008 16:39:31 生成) 对于线程 1 是必需的
ORA-00289: 建议:
E:\ORACLE\PRODUCT\10.2.0\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2008_06_22\O1_MF_1_
13_%U_.ARC
ORA-00280: 更改 6432534 (用于线程 1) 在序列 #13 中

指定日志: {=suggested | filename | AUTO | CANCEL}
E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO02.LOG
已应用的日志。
完成介质恢复。
SQL> alter database open;
alter database open
*
第 1 行出现错误:
ORA-01589: 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项
SQL> alter database open resetlogs;
数据库已更改。

时间: 2024-11-13 09:34:46

(转载)数据库出现ORA-00283/ORA-01610的问题的相关文章

转载《Oracle的tnsnames.ora配置(PLSQL Developer)》

今天是重要的一天.将XML数据导入ORACLE遇到很多问题,学了好多,其中很长时间花在网络配置上,刚开始学,具体原因不知道,先把搜集到的好文章存下来,以后慢慢研究. 监听配置文件             为了使得外部进程 如 CAMS后台程序 能够访问 Oracle 数据库 必须配             置 Oracle 网络服务器环境 配置 Oracle 网络服务器环境是通过配置             listener.ora sqlnet.ora 和 tnsnames.ora 共三个文件

oracle的listener.ora sqlnet.ora tnsnames.ora三个文件的关联性

学习:http://www.cnblogs.com/william-lee/archive/2010/10/20/1856261.html 之前因为安装的是windows server 2008 r2的系统,oracle是11g r2 64bit,因为像很多网友一样,无法使用pl/sql developer 8连接oracle,今天可算连上了,对listener.ora sqlnet.ora tnsnames.ora三个文件.TNSListener服务的认识也深了一层. 先说说我是怎么样连接上的

ORACLE RAC 下非缺省端口监听配置(listener.ora tnsnames.ora)

不论是单实例还是RAC,对于非缺省端口下(1521)的监听器,pmon进程不会将service/instance注册到监听器,即不会实现动态注册.与单实例相同,RAC非缺省端口的监听器也是通过设置参数local_listener来达到目的.除此之外,还可以对实例进行远程注册,以达到负载均衡的目的.这是通过一个参数remote_listener来实现. 有关Oracle 网络配置相关基础以及概念性的问题请参考:      配置ORACLE 客户端连接到数据库   配置非默认端口的动态服务注册   

(转)认识oracle中的sqlnet.ora tnsnames.ora listener.ora三个文件

概述 在oracle安装目录$HOME/network/admin下,,经常看到sqlnet.ora tnsnames.ora listener.ora这三个文件,除了tnsnames.ora,其他两个文件详细的用途很多人都不太了解.sqlnet.ora 用在oracle client端,用于配置连接服务端oracle的相关参数. tnsnames.ora 用在oracle client端,用户配置连接数据库的别名参数,就像系统中的hosts文件一样.listener.ora 用在oracle

listener.ora/sqlnet.ora/tnsnames.ora配置文件详解

oracle网络配置 三个配置文件 listener.ora.sqlnet.ora.tnsnames.ora ,都是放在$ORACLE_HOME/network/admin目录下. 英文说明: The sqlnet.ora is an optional file expressing more parameters about the connection (eg: the trace level for debugging, the types of authentication you wo

oracle的sqlnet.ora , tnsnames.ora , Listener.ora 文件的作用(转)

oracle网络配置三个配置文件 listener.ora.sqlnet.ora.tnsnames.ora ,都是放在$ORACLE_HOME/network/admin目录下.1. sqlnet.ora-----作用类似于linux或者其他unix的nsswitch.conf文件,通过这个文件来决定怎么样找一个连接中出现的连接字符串.例如我们客户端输入sqlplus sys/[email protected]假如我的sqlnet.ora是下面这个样子SQLNET.AUTHENTICATION_

[转载]数据库外键的使用

[转载]数据库外键的使用 外键的作用: 保持数据一致性,完整性,主要目的是控制存储在外键表中的数据. 使两张表形成关联,外键只能引用外表中的列的值! 例如: a b 两个表 a表中存有客户号,客户名称 b表中存有每个客户的订单 有了外键后 你只能在确信b 表中没有客户x的订单后,才可以在a表中删除客户x 建立外键的前提: 本表的列必须与外键类型相同(外键必须是外表主键). 指定主键关键字: foreign key(列名) 引用外键关键字: references <外键表名>(外键列名) 事件触

Win7x64中使用PowerDesigner连接Oralce数据库报“[Oracle][ODBC][Ora]ORA-12154:TNS:无法解析指定的连接标识符”错误解决方法

错误描述 操作系统是Win7 x64,Oracle服务端是Oracle11g x64,客户端是Oracle10gR2 x86. 使用PL-SQL Developer连接正常 使用系统ODBC连接正常.这里要注意的是,64位系统默认启动的是64位ODBC数据源管理器,默认指向的是服务端连接,所以需要为Oracle服务端也配置TNS Service Name,否则同样会连接报错.PowerDesigner默认启动的是32位的ODBC数据源管理器,程序路径为“%SystemRoot%\SysWOW64

oracle的sqlnet.ora,tnsnames.ora,listener.ora三个配置文件

总结:1 .三个配置文件都是放在$ORACLE_HOME\network\admin目录下.2 .sqlnet.ora确定解析方式3 .listener.ora上设SID_NAME,通常用于JDBC访问,对应的错误码为125054 .tnsnames.ora上设SERVICE_NAME,通常用于linux sqlplus客户端,对应的错误码为12514 sqlnet.ora 作用类似于linux或者其他unix的 nsswitch.conf文件,通过这个文件来决定怎么样找一个连接中出现的连接字符

[转载] 数据库的垂直切分和水平切分

转载自http://blog.csdn.net/kobejayandy/article/details/8775138 数据切分可以是物理上的,对数据通过一系列的切分规则将数据分布到不同的DB服务器上,通过路由规则路由访问特定的数据库,这样一来每次访问面对的就不是单台服务器了,而是N台服务器,这样就可以降低单台机器的负载压力. 数据切分也可以是数据库内的,对数据通过一系列的切分规则,将数据分布到一个数据库的不同表中,比如将article分为article_001,article_002等子表,若