就是在两台服务器上分别都有一个数据库,
A服务器有oracle_a数据库;
B服务器有oracle_b数据库;它们都有一个表table_db; 且表结构是一样的,
 
怎么实现oracle_a 和oracle_b 下table_db表的数据同步?且应用系统a会对oracle_a.table_db进行读写, 
  应用系统b会对oracle_b.table_db进行读写,然后,怎么实现数据的双向同步? 

解决方案 »

  1.   

    做dblink, 然后用触发器。
    我认为这个最简单。不过一旦连接失败,会出现不同步。如果2个在一个机器上,则没有问题。
      

  2.   

    用dblink能不能举个例子啊,,,表之间怎么同步呢?
      

  3.   

    参考:
    http://www.sosdb.com/article/article-01.htm
    用ORACLE的高级复制实现内外网数据同步
      

  4.   

    是不是可以在表中加一个时间戳的字段,
    然后定义一个作业调度适时更新?或者把最新更新的记录用平面文件存储起来,通过sqlldr导入导出?
    (这种方式控制粒度较细,性能也比较好,用得很多)
      

  5.   

    是这样的,我有两台服务器,,共同维护一个数据库A....这是如果有一台服务器网络断开时,就要启动本地数据库B...等网络恢复后,把本地的数据在同步到公用的数据库A上。
      

  6.   


    你的意思是要建一台备用的数据库服务器,
    一台出现问题立即启动另一台,
    当两台服务器都可用的情况下同步数据,我理解对吗?这个需求实际上是一个高可用性的需求,
    oracle有现成的解决方案的,不需要自己再开发设计,
    楼主可以先了解下Oracle RAC,看这种方案是否适合你
    http://epub.itpub.net/4/3.htm
      

  7.   

    加我msn可以吗,,我给你细说一下[email protected]
      

  8.   

    我下午就放春节假了,要办手续清理东西,不能跟踪这个问题了,sorryhappy new year to everyone~~~~~~
      

  9.   

    自已研究吧, oracle RAC,DG 正是你要的东东,这是oracle高可用性方面的技术。
      

  10.   

    没有这么麻烦,两台主机共一个磁盘柜就OK, 两台主机做一个cluster,一台主机有问题,就会切换到另一台上去。各大公司都有现成的解决方案,写程式来做具有不可控制的因素。
      

  11.   

    说白了就是主备用数据库数据同步的问题
    如果数据库A和数据库B是建立在两台独立的数据库服务器上,那么采用dblink方式是一种可行的方式,
    按照楼主说的情况,存在两个数据同步过程:一、数据库A正常运行的时候需要将数据同步到备用库即数据库B;二、数据库A不正常的时候启用数据库B,在数据库A恢复正常之前的数据更新都发生在数据库B,那么需要将数据库B的数据同步给数据库A。
    第一种方式:前提是数据库A和数据库B本地网是24小时互通的同时对数据同步实时性有比较高的要求,那么可以建立DBLINK,在两个库都建触发器,不管当前在哪个库发生数据更新的时候实时同步数据到目标数据库;
    第二种方式:如果数据同步的实时性要求不高,则可以通过定制存储过程的方式(给两个库的数据表加时间戳或者更新标志,)定时同步数据;
    第三种方式:通过给两个数据库的数据表加更新标志字段,以第一种方式为主以满足实时性的要求,以第二种方式为辅弥补可能存在的触发器执行更新未成功的情况。以上的方案都是从数据层面所做的处理,对于数据实时同步还是会存在一定的风险,那么双机热备应该说是最好的选择了。