ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 通过数据库链查询会导致源和目标库SCN同步

通过数据库链查询会导致源和目标库SCN同步

原创 Linux操作系统 作者:organist 时间:2012-05-08 16:29:15 0 删除 编辑
  
在通过数据库链执行跨数据库的查询时,Oracle会自动将两个数据库的SCN进行同步。()
SQL> conn scott/tiger@xxx
SQL> SELECT current_scn FROM v$database;
SQL> conn scott/tiger@yyy
SQL> SELECT current_scn FROM v$database;
SQL> CREATE  DATABASE  link  ora102044  CONNECT  TO  test  IDENTIFIED BY  test  USING  'xxx';
SQL> SELECT current_scn FROM v$database@xxx
SQL> SELECT current_scn FROM v$database;
SQL> conn scott/tiger@xxx
SQL> SELECT current_scn FROM v$database;

可以看到,在通过数据库链执行查询后,Oracle会同步两个数据库的SCN,取两个数据库最大的SCN作为新的SCN,执行查询时刻,两个数据库的SCN一致。
Oracle的这个机制应该是为了分布式查询的一致性,这样一个查询只需要一个SCN就可以在分布式查询的任何一个数据库中来获取一致性。
但是这种实现也会存在一定的潜在问题,其中一个数据库的SCN可能会从一个较低的数值,一下增长到一个很高的数据。
这个例子中,ORA102044数据库 的SCN就增加了一倍以上。而对于实际环境中,SCN的增加可能是几倍、几十倍甚至是上百倍,从而引发一些其他的bug。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26953882/viewspace-723054/,如需转载,请注明出处,否则将追究法律责任。

上一篇: oracle rman command
请登录后发表评论 登录
全部评论

注册时间:2012-05-08

  • 博文量
    17
  • 访问量
    19630