重庆思庄Oracle、Redhat认证学习论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1219|回复: 0
打印 上一主题 下一主题

[Oracle] oracle查询scn

[复制链接]
跳转到指定楼层
楼主
发表于 2023-10-17 15:15:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 jiawang 于 2023-10-17 16:15 编辑

Oracle数据库使用SCN(系统更改号)来保存在连接到数据库时事务发生的序列号。
SCN是保存在数据库里的一个系统变量,可以帮助数据库识别什么时候有改动发生,有什么改动。
要检索当前可用的SCN,可以查询v$database视图:
SQL> SELECT current_scn FROM v$database;
CURRENT_SCN
---------
17955930
这样可以确定当前正在使用的SCN号为17955930.


另外一种查询SCN的方法是使用Oracle控制文件。如果你熟悉V$controlfile视图,可以使用:
SQL> SELECT resetlogs_change# FROM v$controlfile;
RESETLOGS_CHANGE#
---------------
190431

以上实验查询出的重置日志更改号为190431,它也是一个SCN值。

我们可以使用Oracle提供的函数,来获取当前正在使用的SCN。
SQL> SELECT dbms_flashback.get_system_change_number FROM dual;
GET_SYSTEM_CHANGE_NUMBER
-----------------------
20253306

以上查询使用DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER函数,可以检索当前正在使用的SCN。以上查询出来的SCN是20253306。


总之,要查询Oracle数据库中当前使用的SCN,可以使用v$database和v$controlfile视图,也可以使用dbms_flashback.get_system_change_number函数来实现。



分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-11-1 07:46 , Processed in 0.094218 second(s), 21 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

快速回复 返回顶部 返回列表