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

  
在通过数据库链执行跨数据库的查询时,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/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/26953882/viewspace-723054/

你可能感兴趣的:(通过数据库链查询会导致源和目标库SCN同步)