如何实现两个数据库同步部分表的数据

如何实现两个数据库同步部分表的数据,第1张

同一服务器的两个库同步数据,比如同步两个库的Name字段

  UPDATE  b

    SET     b.[Name] = a.[Name]

    FROM    数据库1.dbo.News a

            INNER JOIN 数据库2.dbo.News1 b ON a.Id = b.Id

不同数据库需要建立链接服务器,然后用:

UPDATE  b

    SET     b.[Name] = a.[Name]

    FROM    数据库1.dbo.News a

            INNER JOIN 链接服务器名称.数据库2.dbo.News1 b ON a.Id = b.Id

在pgsql的数据库中将要同步的表建立一个一模一样的同步表。然后建触发器,将进入源表中的数据触发到同步表中。然后做一个windows服务扫描这个同步表并且将同步表中的数据同步到mysql

或access中。

如果是整个数据库中有许多表要进行同步。则建立一个共用的同步表,结构非常简单。字段如下:

主键(f_id),源表名(f_tablename),主键字段名(f_keyname),主键值(f_keyvalue), *** 作标识(f_operflag

i:插入

u:更新

d:删除),时间字段(f_time).将要同步的表都建立触发器,只要有增、改、删都触发到这个表里。这样你只扫描这个共用的同步表,根据这些字段值完全可以实现数据的同步。隔离网闸就是这么个原理,只不过它的要比这复杂多了!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6762066.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-27
下一篇 2023-03-27

发表评论

登录后才能评论

评论列表(0条)

保存