此类错误可能发生在服务器电源突然失败(使用备份控制文件进行恢复)

报错类型:

SQL> alter database open
*
ERROR at line 1:
ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1],
[23], [81], [189], [], [], [], [], [], [], []

解决方案:

 1.查看控制文件位置与当前oracle使用的联机重做日志文件

SQL> Show parameter control_files;

NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
control_files string D:\APP\MAZAR\ORADATA\ORCL\CONT
ROL01.CTL, D:\APP\MAZAR\FLASH_
RECOVERY_AREA\ORCL\CONTROL02.C
TL
SQL> select a.member,a.group#,b.status from v$logfile a ,v$log b where a.group#=b.group# and b.status='CURRENT';

MEMBER
--------------------------------------------------------------------------------

GROUP# STATUS
---------- ----------------
D:\APP\MAZAR\ORADATA\ORCL\REDO02.LOG
2 CURRENT

2.关闭数据库,并备份控制文件

C:\Windows\system32>COPY D:\APP\MAZAR\ORADATA\ORCL\CONTROL01.CTL D:\APP

1 file(s) copied.

3.挂载数据库并使用控制日志与联机重做日志进行恢复

SQL> recover database using backup controlfile until cancel;
ORA-00279: change 1460665 generated at 10/08/2012 08:38:00 needed for thread
ORA-00289: suggestion :
D:\APP\MAZAR\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2012_10_14\O1_MF_1_23_%U_.ARORA-00280: change 1460665 for thread 1 is in sequence #23
Specify log: {<RET>=suggested | filename | AUTO | CANCEL}
D:\APP\MAZAR\ORADATA\ORCL\REDO02.LOG
Log applied.
Media recovery complete.

4.打开数据库,并重置日志文件

SQL> alter database open resetlogs;

Database altered.


参考文件:

http://mohamedazar.com/2012/10/14/ora-00600-kcratr_nab_less_than_odr-when-alter-database-open-fails/