http://blog.csdn.net/yorck/archive/2004/07/23/49532.aspx

解决方案 »

  1.   

    如果不是从硬件实现,较为简单的是触发器+dblink的方法实现比较简单
      

  2.   

    触发器和dblink怎么实现?可以说详细点吗?谢谢!!!!
      

  3.   

    ORACLE的分布式管理 1999-12 余枫    物理上存放于网络的多个ORACLE数据库,逻辑上可以看成一个单个的大数
    据库。用户可以通过网络对异地数据库中的数据同时进行存取,而服务器之间
    的协同处理对于工作站用户及应用程序而言是完全透明的:开发人员无需关心
    网络的链接细节、无需关心数据在网络接点中的具体分布情况、也无需关心服
    务器之间的协调工作过程。    数据库之间的链接建立在DATABASE LINK上。要创建一个DB LINK,必须先
    在每个数据库服务器上设置链接字符串。   例如,深圳SUN平台ORACLE数据库,在/var/opt/oracle/tnsnames.ora中有以下
    一条和北京的数据库链接tobeijing,格式如下:链接字符串的设置 说       明
     
    tobeijing=(description= database link名称:tobeijing 
    (address=(protocol=tcp) 采用tcp/ip协议 
    (host=www.bj.col.com.cn) 欲链接主机名称或IP地址 
    (port=1521)) 网络端口1521  
    (connect_data=(sid=oracle7))) 安装ORACLE采用的sid 然后进入系统管理员SQL>操作符下,运行命令:SQL>create public database link beijing connect to scott identified by tiger 
               using 'tobeijing';则创建了一个以scott用户和北京数据库的链接beijing,我们查询北京的scott数据:SQL>select * from emp@beijing; 这样就可以把深圳和北京scott用户的数据做成一个整体来处理。为了使有关分布式操作更透明,ORACLE数据库里有同义词的对象synonymSQL>create synonym bjscottemp for emp@beijing;于是就可以用bjscottemp来替代带@符号的分布式链接操作emp@beijing。
    建立好DB_LINGK以后使用这个DB_LINGK(beijing)在本地数据库上建立触发器,只要本地数据库数据发生改变就写,另外机器的数据库。