急急急,请教高手在SQL server中如何用触发器实现两个不同服务器上的相同数据库表的数据同步?

hxy825 2013-04-12 08:44:19
现在在同一局域网内有Srv1和Srv2两台服务器,都安装有数据库SQL server2000,两个数据库中都建立了相同的数据库“test”,并且都有一个相同的“table1”表,如何写SQL server触发器来实现当Srv1服务器中的“table1”表数据发生变化时Srv2服务器中的“table1”表也能跟着变以实现两个数据表同步呢?“table1”表结构为:create table table1(DJBH int identity,DJJE numeric(19,2))。我的处理步骤是:
1、--在A服务器上建立B服务器连接
exec sp_addlinkedserver 'Srv2','','SQLOLEDB','test'
exec sp_addlinkedsrvlogin 'Srv2','false',null,'sa',''
go

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

3、创建同步处理触发器
if (object_id('Trigger1', 'TR') is not null) drop trigger Trigger1
go
create trigger Trigger1 ON table1
after insert
as
begin
set xact_abort on --如果执行 Transact-SQL 语句产生运行时错误,则整个事务将终止并回滚。
set nocount on
set insert Srv2.test.table1(DJBH,DJJE)
select DJBH,DJJE from inserted
end

可是我试验的执行:insert into table1(DJBH, DJJE) values(1, 100) 后总是提示“对象名Srv2.test.table1”无效呢,有劳高手们指点一下到底是哪里出现问题了呢?谢谢
...全文
480 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
xuexiaodong2009 2013-04-17
  • 打赏
  • 举报
回复
跟我的问题一模一样啊,可惜我的问题没人解决 有很多原因 可以参考下http://bbs.csdn.net/topics/390428294?page=1#post-394226149
大力水手 2013-04-17
  • 打赏
  • 举报
回复
我感觉触发器是一个很不好的选择, 特别是跨服务器的。更重要的是你的数据是SQL server 2000。 你要了解出触发器执行的原理. SQL server 2000 的时候还没有行版本控制技术。 所以他的触发器一点都不成熟。他是通过逆序扫描日志来。 也就是我磁盘的磁头在滋滋滋的往前写入的时候。你突然就往回去读。 这会影响数据库性能。一个事务提交唯一往磁盘里写的东西就是日志。这样也会影响后续事务的提交时间 SQL server 2005 及以上版本。通过行版本控制技术。其原理大概就是每个事务都有自己的事务id, 通过事务id把行的另一个版本放在TEMPDB 的存储区域里维护。也就是不会再逆序扫描日志了。但是你要 更重视你的TEMPDB了。有可能一个很大的事务就能把你TEMP搞到10几个G那么大。也会越来越重视TEMPDB的性能问题。 所以如果你的同步不要求实时性,你可以根据某一列(主键,唯一标示都行)把数据抽取过来。 忘能帮助你。
弘恩 2013-04-17
  • 打赏
  • 举报
回复
一般情况下,事务下不能封装链接服务器,因为在触发器里面的操作会默认为一个事务中的操作
rockyshi123 2013-04-16
  • 打赏
  • 举报
回复
这个实现方法本身就不好,你可以用两个数据库之间的复制和订阅来实现
hxy825 2013-04-16
  • 打赏
  • 举报
回复
我后面又修改了代码如下: exec sp_addlinkedserver 'srv2','','SQLOLEDB.1','192.168.10.11' exec sp_addlinkedsrvlogin 'srv2','false',null,'sa','' go if (object_id('Trigger1', 'TR') is not null) drop trigger Trigger1 go create trigger Trigger1 ON table1 for insert AS set xact_abort on set insert srv2.test.dbo.table1(DJBH,DJJE) select DJBH,DJJE from inserted go 现在我是在客户端的SQL server查询分析器中直接访问到Srv1服务器上的test数据库中执行的,此时在SQL server中能直接查询到Srv2上的数据表呢,就是奇怪了,在往Srv1数据表中table1中插入数据时总是提示:OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务,有劳大伙帮忙分析一下啊,谢谢
hxy825 2013-04-16
  • 打赏
  • 举报
回复
主要是Srv1上的数据库是需要经常删除数据的,只是Srv1新增和修改数据时要求Srv2数据库实时同步呢,如果是定时同步的话就不能实现实时性了呢!
qiuchu2003 2013-04-15
  • 打赏
  • 举报
回复
把“Srv2.test.table1”改成“Srv2.test.dbo.table1”试试
hxy825 2013-04-14
  • 打赏
  • 举报
回复
自己先顶一下,有劳高手们指点一下,万分感谢
内容简介   《google android sdk开发范例大全(第3版)》在上一版的基础上,以android手机应用程序开发(采用android sdk 2.3.3)为主题,超过200多个范例全面且深度地整合了手机、网络及服务等多个开发领域,为读者提高程序设计能力提供了很大的帮助。    全书共分11章,主要以范例集的方式来讲述android的知识点,详细介绍了开发android的人机交互界面、android常用的开发控件、android手机收发短信等通信服务、开发android手机的自动服务功能和娱乐多媒体功能以及整合android与google强大的网络服务等内容。随书光盘包括了所有范例的程序代码。    《google android sdk开发范例大全(第3版)》继承前两版由浅入深的方式,范例总数由原先的160多个增加到了200多个,在用户交互界面、手机控件、交互式通信服务、手机自助服务、娱乐多媒体等方面均增加了相应的范例来介绍新的开发技术,特别是新增加了第11章来专门介绍html5技术在android移动设备里的应用,相信当下两个热门技术的交汇会碰撞出不一样的火花。    《google android sdk开发范例大全(第3版)》内容由android的基础知识到实际开发应用,结构清晰、语言简洁,非常适合android的初学者和android的进阶程序开发者阅读参考。 目录 《google android sdk开发范例大全(第3版)》 第1章 了解、深入、动手做 1 1.1 红透半边天的android 2 1.2 本书目的及范例涵盖范围 3 1.3 如何阅读本书 4 1.4 使用本书范例 5 1.5 参考网站 6 第2章 android初体验 7 2.1 安装android sdk与adt/ddms 8 2.2 创建第一个android项目(hello android!) 11 2.3 android应用程序架构——从此开始 15 2.4 可视化的界面开发工具 18 2.5 部署应用程序到android手机 19 第3章 用户人机界面 22 3.1 更改与显示文字标签 23 3.2 更改手机窗口画面底色 24 3.3 更改textview文字颜色 26 3.4 置换textview文字 28 3.5 取得手机屏幕大小 29 3.6 样式化的定型对象 30 .3.7 简易的按钮事件 32 3.8 手机页面的转换 34 3.9 调用另一个activity 37 3.10 不同activity之间的数据传递 41 3.11 返回数据到前一个activity 44 3.12 具有交互功能的对话框 49 3.13 置换文字颜色的机关 51 3.14 控制不同的文字字体 52 3.15 如iphone拖动相片特效 54 3.16 自制计算器 56 3.17 关于(about)程序信息 58 3.18 程序加载,请稍候 61 3.19 全屏幕以按钮重写 63 3.20 今晚到哪儿打牙祭 64 3.21 android变脸 67 3.22 打勾显示输入的密码 69 3.23 android多语系支持 71 3.24 判断手机操作系统版本是否允许运行程序 72 3.25 两个不同的程序彼此调用 75 3.26 指定安装应用程序迁移至sd卡 78 3.27 手机动态layout主题随手势物换迁移 79 第4章 史上超豪华的手机控件 84 4.1 edittext与textview共舞 85 4.2 设计具有背景图的按钮 86 4.3 给圣诞老人的信息 88 4.4 我同意条款 90 4.5 消费券采购列 92 4.6 向左或向右 94 4.7 专业相框设计 96 4.8 自定义下拉菜单模式 99 4.9 动态添加/删除的spinner菜单 102 4.10 心爱小宝贝相片集 104 4.11 快速地搜索手机文件引擎 107 4.12 按钮也能随单击变换 109 4.13 具自动提示功能的菜单 110 4.14 数字及模拟小时钟设计 112 4.15 动态输入日期与时间 114 4.16 猜猜红桃a在哪儿 117 4.17 后台程序运行进度提示 121 4.18 动态文字排版 124 4.19 在activity里显示列 128 4.20 以动态列配置选项 130 4.21 查找程序根目录下所有文件 134 4.22 加载手机磁盘里的图片文件 137 4.23 动态放大缩小imageview里的图片 139 4.24 动态旋转图片 142 4.25 猜猜我在想什么 145 4

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧