通过GDB推进数据库SCN(适用于12c及以上)

经测试发现,数据库mount和open状态下都可以通过此方法推进SCN。
Session1:
查询当前SCN

SQL> select current_scn from v$database;                

CURRENT_SCN
-----------
 2910718245

查询当前SCN转成16进制后的值

SQL> select to_char(2910718245,'xxxxxxxxxxxx') from dual;

TO_CHAR(29107
-------------
     ad7e0925

查询预修改的SCN转换成16进制后的值

SQL> select to_char(3910718245,'xxxxxxxxxxxx') from dual;

TO_CHAR(39107
-------------
     e918d325

SQL> 
SQL> oradebug setmypid
Statement processed.
SQL> oradebug dumpvar sga kcsgscn_
kscn8 kcsgscn_ [060017E98, 060017EA0) = AD7E093B 00000000

060017E98是SCN BASE值,我们待会修改的就是他,修改成多少,数据库SCN就是多少
AD7E093B是当前的SCN值,可以理解为060017E98是一个代号x,当前的x等于AD7E093B

Session2:

[oracle@redhat19c11 ~]$ ps -ef|grep LOCAL=YES
oracle    9824  9730  0 Feb22 ?        00:00:01 oracleorcl (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))
oracle   18621  8636  0 01:18 pts/1    00:00:00 grep --color=auto LOCAL=YES
oracle   20109 20105  0 Feb15 ?        00:00:13 oracletestdb19c (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))

本次测试库是orcl,因此选9824

[oracle@redhat19c11 ~]$ gdb $ORACLE_HOME/bin/oracle 9824
GNU gdb (GDB) Red Hat Enterprise Linux 7.6.1-114.el7
Copyright (C) 2013 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-redhat-linux-gnu".
For bug reporting instructions, please see:
。。。。。。(中间省略)
(gdb) set *((int *) 0x060017E98) = 0xe918d325        --->将SCN BASE修改为刚才查出来的值
(gdb) quit
A debugging session is active.

        Inferior 1 [process 9824] will be detached.

Quit anyway? (y or n) y
Detaching from program: /oracle/app/product/19.3.0/db_1/bin/oracle, process 9824

返回session1查询,修改成功:

SQL> select current_scn from v$database;

CURRENT_SCN
-----------
 3910718287

重启数据库,也正常:

SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup;
ORACLE instance started.

Total System Global Area 2466250400 bytes
Fixed Size                  9137824 bytes
Variable Size             603979776 bytes
Database Buffers         1845493760 bytes
Redo Buffers                7639040 bytes
Database mounted.
Database opened.
SQL> select current_scn from v$database;

CURRENT_SCN
-----------
 3910719415

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-09 18:02:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-09 18:02:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-09 18:02:04       87 阅读
  4. Python语言-面向对象

    2024-04-09 18:02:04       96 阅读

热门阅读

  1. 多数据源解决事务问题

    2024-04-09 18:02:04       32 阅读
  2. 单例模式

    2024-04-09 18:02:04       39 阅读
  3. TLC3702双微功耗电压比较器

    2024-04-09 18:02:04       40 阅读
  4. 除了sql外还有那些查询语言

    2024-04-09 18:02:04       40 阅读
  5. C++:std命名空间及输入输出流

    2024-04-09 18:02:04       33 阅读
  6. 蓝桥杯——求和

    2024-04-09 18:02:04       35 阅读
  7. oracle回收表空间

    2024-04-09 18:02:04       34 阅读
  8. 不同于Oracle:SEQUENCE的区别

    2024-04-09 18:02:04       28 阅读
  9. 进入Docker容器内部的文件夹

    2024-04-09 18:02:04       38 阅读
  10. css设置主题变量

    2024-04-09 18:02:04       35 阅读
  11. PostCss:详尽指南之安装和使用

    2024-04-09 18:02:04       34 阅读
  12. iOS自定义初始化方法

    2024-04-09 18:02:04       30 阅读
  13. 在Windows系统上下载并安装MySQL的详细教程

    2024-04-09 18:02:04       35 阅读
  14. 本地文件转为MultipartFile,图片地址转MultipartFile

    2024-04-09 18:02:04       38 阅读
  15. 如何动态往Spring容器注册/移除bean?

    2024-04-09 18:02:04       35 阅读
  16. pe格式从入门到图形化显示(五)-RVA和FOA

    2024-04-09 18:02:04       36 阅读
  17. 记一个Unity的异常问题

    2024-04-09 18:02:04       37 阅读
  18. UVA10391 Compound Words 复合词 解题报告

    2024-04-09 18:02:04       29 阅读