加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何解决源和目标库SCN同步问题

发布时间:2020-12-12 16:18:55 所属栏目:百科 来源:网络整理
导读:以前有个朋友向我提过这个问题:大家通过数据库链执行跨数据库的查询时,可能都会遇到 Oracle 将两个数据库的 SCN 同步的问题,今天就来解决一下。 SQL conn test/test@192.168.0.19:1666/ora102044 Connected. SQL select current_scn from v$database; CUR

以前有个朋友向我提过这个问题:大家通过数据库链执行跨数据库的查询时,可能都会遇到Oracle将两个数据库的SCN同步的问题,今天就来解决一下。

SQL> conn test/test@192.168.0.19:1666/ora102044
Connected.
SQL> select current_scn from v$database;

CURRENT_SCN
-----------
2745758

SQL> conn test/test@192.168.0.20:15210/orcl
Connected.
SQL> select current_scn from v$database;

CURRENT_SCN
-----------
5642527

SQL> create database link ora102044
2 connect to test
3 identified by test
4 using '192.168.0.19:1666/ora102044';

Database link created.

SQL> select current_scn from v$database@ora102044;

CURRENT_SCN
-----------
5642628

SQL> select current_scn from v$database;

CURRENT_SCN
-----------
5642638

CURRENT_SCN
-----------
5642702

  可以看到,在通过数据库链执行查询后,Oracle会同步两个数据库的SCN,取两个数据库最大的SCN作为新的SCN,执行查询时刻,两个数据库的SCN一致。

  Oracle的这个机制应该是为了分布式查询的一致性,这样一个查询只需要一个SCN就可以在分布式查询的任何一个数据库中来获取一致性。

  但是这种实现也会存在一定的潜在问题,其中一个数据库的SCN可能会从一个较低的数值,一下增长到一个很高的数据。这个例子中,ORA102044数据库的SCN就增加了一倍以上。而对于实际环境中,SCN的增加可能是几倍、几十倍甚至是上百倍,从而引发一些其他的bug

  本文就暂且介绍到这里,希望能给大家以帮助。


转自北京CUUG培训

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读