博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
同步两个数据库
阅读量:6164 次
发布时间:2019-06-21

本文共 1134 字,大约阅读时间需要 3 分钟。

hot3.png

参考:

--引用邹建
/*--同步两个数据库的示例

测试环境及同步要求:

有数据库服务器srv1和srv2,两台电脑能互相访问,有数据

srv1.库名..author有字段:id,name,phone,
srv2.库名..author有字段:id,name,telphone,adress

要求:

srv1.库名..author增加记录则srv1.库名..author记录增加
srv1.库名..author的phone字段更新,则srv1.库名..author对应字段telphone更新
--*/

--大致的处理步骤

--1.在 srv1 上创建连接服务器,以便在 srv1 中操作 srv2,实现同步
exec sp_addlinkedserver  'srv2','','SQLOLEDB','srv2的sql实例名或ip'
exec sp_addlinkedsrvlogin 'srv2','false',null,'用户名','密码'
go

--2.在 srv1 和 srv2 这两台电脑中,启动 msdtc(分布式事务处理服务),并且设置为自动启动

我的电脑--控制面板--管理工具--服务--右键 Distributed Transaction Coordinator--属性--启动--并将启动类型设置为自动启动
go

--3.实现同步处理

--a.在srv1..author中创建触发器,实现数据即时同步

--新增同步

create trigger tr_insert_author on authorfor insertasset xact_abort oninsert srv2.库名.dbo.author(id,name,telphone)select id,name,telphone from insertedgo

--修改同步

create trigger tr_update_author on authorfor updateasset xact_abort onupdate b set name=i.name,telphone=i.telphonefrom srv2.库名.dbo.author b,inserted iwhere b.id=i.idgo

--删除同步

create trigger tr_delete_author on authorfor deleteasset xact_abort ondelete b from srv2.库名.dbo.author b,deleted dwhere b.id=d.idgo

转载于:https://my.oschina.net/u/1462678/blog/227143

你可能感兴趣的文章
3springboot:springboot配置文件(外部配置加载顺序、自动配置原理,@Conditional)
查看>>
图解SSH原理及两种登录方法
查看>>
查询个人站点的文章、分类和标签查询
查看>>
基础知识:数字、字符串、列表 的类型及内置方法
查看>>
JSP的隐式对象
查看>>
JS图片跟着鼠标跑效果
查看>>
Leetcode 3. Longest Substring Without Repeating Characters
查看>>
416. Partition Equal Subset Sum
查看>>
app内部H5测试点总结
查看>>
[TC13761]Mutalisk
查看>>
while()
查看>>
常用限制input的方法
查看>>
IIS7下使用urlrewriter.dll配置
查看>>
并行程序设计学习心得1——并行计算机存储
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>