1.poke推进scn修复(针对2662)(ORA-600 [2662] [a] [b] [c] [d] [e])(12.2以下可以使用)
1.查看当前数据库的Current SCN
SYS@orcl> select current_scn||‘’ from v$database;
CURRENT_SCN||‘’
————————
4563483988
可以看到当前SCN是4563483988,我现在想推进SCN,在10w级别,也就是4563483988标红数字修改为指定值。
2.重新启动数据库到mount阶段
SYS@orcl> shutdown abort
ORACLE instance shut down.
SYS@orcl> startup mount
ORACLE instance started.
Total System Global Area 1235959808 bytes
Fixed Size 2252784 bytes
Variable Size 788529168 bytes
Database Buffers 436207616 bytes
Redo Buffers 8970240 bytes
Database mounted.
3.使用oradebug poke推进SCN
我这里直接把十万位的"4"改为"9"了,相当于推进了50w左右: 说明:实验发现oradebug poke 推进的SCN值,既可以指定十六进制的0x11008DE74,也可以直接指定十进制的4563983988。
1.指定进程
SYS@orcl> oradebug setmypid
Statement processed.
查看kcsgscn_
SYS@orcl> oradebug dumpvar sga kcsgscn_
kcslf kcsgscn_ [06001AE70, 06001AEA0) = 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 6001AB50 00000000
这步没用
SYS@orcl> select to_char(checkpoint_change#, ‘XXXXXXXXXXXXXXXX’) from v$database;
TO_CHAR(CHECKPOINT_CHANGE#,'XXXXXX
——————————————————————
110013C41
修改,poke
这里的0x06001AE70见oradebug dumpvar sga kcsgscn_出来的部分,8是固定的,4563983988是自己想要到的scn位置
SYS@orcl> oradebug poke 0x06001AE70 8 4563983988
BEFORE: [06001AE70, 06001AE78) =