有2个数据库,怎么实现数据同步

有2个数据库,怎么实现数据同步,第1张

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

或access中。

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

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

i:插入

u:更新

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

1.直接方法,将需要的查询的数据赋值到excel中。相应调整,然后再赋值到目标表中(对于数据量不大的情况下较快)

2.最好两数据库拥有相同的登录名和密码不然比较麻烦

insert

into

目标数据库.dbo.目标表名(字段1...字段n)

select

段1...字段n

from

源数据库.dbo.源表名

select

段1...字段n

into

目标数据库.dbo.目标表名

from

源数据库.dbo.源表名

3.这样的插入注意表字段的长度和约束条件,若原表中字段长,就得将目标表中的字段相应加长

具体 *** 作:

1、在分析型数据库上创建目标表,数据更新类型为实时写入,字段名称和MySQL中的建议均相同;

2、在阿里云数据传输的控制台上创建数据订阅通道,并记录这个通道的ID;

3、 配置dts-ads-writer/app.conf文件,配置方式如下:所有配置均保存在app.conf中,运行前请保证配置正确;修改配置后,请重启writer,基本配置:

注意事项:

1、RDS

for

MySQL表和分析型数据库中表的主键定义必须完全一致;如果不一致会出现数据不一致问题。如果需要调整RDS/分析型数据库表的主键,建议先停止writer进程;

2、一个插件进程中分析型数据库db只能是一个,由adsJdbcUrl指定;

3、一个插件进程只能对应一个数据订阅通道;如果更新通道中的订阅对象时,需要重启进程。


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

原文地址:https://54852.com/sjk/10036084.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存