1.如果是同一服务器:
假设 另一个数据库名为'数据库B',并且当然用户对两个数据库都有对应权限
select into [table] from [数据库B].[所有者].[表名]
2.如果不在同一服务器
select into [table] from opendatasource('sqloledb','data source=服务器名或IPuser id=登陆名password=口令').数据库B.表名
在执行的时候,要注意两个表的标示要写完整:数据库名.用户名.表名
例如:
insert into db1.yonghu1.bm
select * from db2.yonghu2.bm
db1和db2是数据库名,yonghu1和yonghu2是数据库的用户名,bm是表名。
在pgsql的数据库中将要同步的表建立一个一模一样的同步表。然后建触发器,将进入源表中的数据触发到同步表中。然后做一个windows服务扫描这个同步表并且将同步表中的数据同步到mysql或access中。
如果是整个数据库中有许多表要进行同步。则建立一个共用的同步表,结构非常简单。字段如下:
主键(f_id),源表名(f_tablename),主键字段名(f_keyname),主键值(f_keyvalue), *** 作标识(f_operflag
i:插入
u:更新
d:删除),时间字段(f_time).将要同步的表都建立触发器,只要有增、改、删都触发到这个表里。这样你只扫描这个共用的同步表,根据这些字段值完全可以实现数据的同步。隔离网闸就是这么个原理,只不过它的要比这复杂多了!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)