如何解决源和目标库SCN同步问题
2016-07-06 14:03
429 查看
以前有个朋友向我提过这个问题:大家通过数据库链执行跨数据库的查询时,可能都会遇到Oracle将两个数据库的SCN同步的问题,今天就来解决一下。 SQL> conn test/test@192.168.0.19:1666/ora102044
Connected.
SQL> select current_scn from v$database;CURRENT_SCN
-----------
2745758SQL> conn test/test@192.168.0.20:15210/orcl
Connected.
SQL> select current_scn from v$database;CURRENT_SCN
-----------
5642527SQL> 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
-----------
5642628SQL> select current_scn from v$database;CURRENT_SCN
-----------
5642638SQL> conn test/test@192.168.0.19:1666/ora102044
Connected.
SQL> select current_scn from v$database;CURRENT_SCN
-----------
5642702 可以看到,在通过数据库链执行查询后,Oracle会同步两个数据库的SCN,取两个数据库最大的SCN作为新的SCN,执行查询时刻,两个数据库的SCN一致。 Oracle的这个机制应该是为了分布式查询的一致性,这样一个查询只需要一个SCN就可以在分布式查询的任何一个数据库中来获取一致性。 但是这种实现也会存在一定的潜在问题,其中一个数据库的SCN可能会从一个较低的数值,一下增长到一个很高的数据。这个例子中,ORA102044数据库的SCN就增加了一倍以上。而对于实际环境中,SCN的增加可能是几倍、几十倍甚至是上百倍,从而引发一些其他的bug。 本文就暂且介绍到这里,希望能给大家以帮助。
转自 北京CUUG培训
Connected.
SQL> select current_scn from v$database;CURRENT_SCN
-----------
2745758SQL> conn test/test@192.168.0.20:15210/orcl
Connected.
SQL> select current_scn from v$database;CURRENT_SCN
-----------
5642527SQL> 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
-----------
5642628SQL> select current_scn from v$database;CURRENT_SCN
-----------
5642638SQL> conn test/test@192.168.0.19:1666/ora102044
Connected.
SQL> select current_scn from v$database;CURRENT_SCN
-----------
5642702 可以看到,在通过数据库链执行查询后,Oracle会同步两个数据库的SCN,取两个数据库最大的SCN作为新的SCN,执行查询时刻,两个数据库的SCN一致。 Oracle的这个机制应该是为了分布式查询的一致性,这样一个查询只需要一个SCN就可以在分布式查询的任何一个数据库中来获取一致性。 但是这种实现也会存在一定的潜在问题,其中一个数据库的SCN可能会从一个较低的数值,一下增长到一个很高的数据。这个例子中,ORA102044数据库的SCN就增加了一倍以上。而对于实际环境中,SCN的增加可能是几倍、几十倍甚至是上百倍,从而引发一些其他的bug。 本文就暂且介绍到这里,希望能给大家以帮助。
转自 北京CUUG培训
相关文章推荐
- 基于 Red Hat 的发行版 Oracle Linux 正式发布Oracle Linux 7.1
- Oracle Containers for J2EE远程安全漏洞(CVE-2014-0413)
- Oracle 10g R2不能使用EM的问题
- 表空间操作
- PreparedStatement中in子句的处理
- VMware下RedHat4.8_64位安装Oracle 10g RAC--简略脚本
- oracle sql日期比较
- 基于 Red Hat 的发行版 Oracle Linux 正式发布Oracle Linux 7.1
- OS block size和Oracle block size,查找OS Blocksize的方法
- oracle中创建数据库和表空间的几点总结
- 数据库自动备份脚本
- oracle的nvl函数的使用介绍
- 解决oracle用户连接失败的解决方法
- oracle的一些tips技巧
- Oracle 下的开发日积月累
- Oracle存储过程之数据库中获取数据实例
- Windows下ORACLE 10g完全卸载的方法分析
- Oracle 函数大全[字符串函数,数学函数,日期函数]第1/4页
- ORACLE LATERAL-SQL-INJECTION 个人见解