表与表数据的部分同步

多难成佛 2012-07-23 09:54:32
数据库D1,表D1_ord。
数据库D2,表D2_ord。
两表字段和数据相同,字段为:id,dt,pName,pSum,ordStatu。

当D1_ord的数据发生变化时(id不会变),将D2_ord中相同id相同dt的记录的对应字段同步更新。
举例一:
D1_ord和D2_ord原有记录:
id dt pName pSum ordStatu
001 20120723 052 1 0

当D1_ord中的pSum被更改为2,ordStatu被更改为1时,在D2_ord中找到id为001、dt为20120723的记录,将对应字段的值也更改为2和1。
---------------------------------------------------------------------------------------------------------
这个想法怎样实现比较好?触发器?存储过程?哪种对性能的影响最小?哪种的可靠性最高?
请不吝赐教!
...全文
109 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
SQL77 2012-07-23
  • 打赏
  • 举报
回复
同一实例下。直接触发器OK了
多难成佛 2012-07-23
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 的回复:]
实时的实现数据同步就用触发器,要不你即时实现用存储过程+作业(针对你的需求估计这个还不如用触发器,LZ酌情选择思路)。建议:针对你的实际需求和数据量可以用触发器


SQL code


--参考:
/* 作者:邹建 */
/*--同步两个数据库的示例
有数据
srv1.库名..author有字段:id,name,phone,
srv2.……
[/Quote]
非常感谢给出例子。是同一实例下的两个库,不是两个实例也不是两个Server
以学习为目的 2012-07-23
  • 打赏
  • 举报
回复
实时的实现数据同步就用触发器,要不你即时实现用存储过程+作业(针对你的需求估计这个还不如用触发器,LZ酌情选择思路)。建议:针对你的实际需求和数据量可以用触发器


--参考:
/* 作者:邹建 */
/*--同步两个数据库的示例
有数据
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
--然后创建一个作业定时调用上面的同步处理存储过程就行了
企业管理器 --管理 --SQL Server代理 --右键作业 --新建作业 --"常规"项中输入作业名称 --"步骤"项 --新建 --"步骤名"中输入步骤名 --"类型"中选择"Transact-SQL 脚本(TSQL)" --"数据库"选择执行命令的数据库 --"命令"中输入要执行的语句: exec p_process --确定 --"调度"项 --新建调度 --"名称"中输入调度名称 --"调度类型"中选择你的作业执行安排 --如果选择"反复出现" --点"更改"来设置你的时间安排 然后将SQL Agent服务启动,并设置为自动启动,否则你的作业不会被执行
设置方法: 我的电脑--控制面板--管理工具--服务--右键 SQLSERVERAGENT--属性--启动类型--选择"自动启动"--确定.
--3.实现同步处理的方法2,定时同步
--在srv1中创建如下的同步处理存储过程
create proc p_process as
--更新修改过的数据
update b set name=i.name,telphone=i.telphone from srv2.库名.dbo.author b,author i where b.id=i.id and (b.name <> i.name or b.telphone <> i.telphone)
--插入新增的数据
insert srv2.库名.dbo.author(id,name,telphone) select id,name,telphone from author i where not exists( select * from srv2.库名.dbo.author where id=i.id)
--删除已经删除的数据(如果需要的话)
delete b from srv2.库名.dbo.author b where not exists( select * from author where id=b.id) go


多难成佛 2012-07-23
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 的回复:]
SQL code



6000 这点数量,怕什么?
楼主要是实在不放心,那你就在程序,在更新数据的时候多写一句更新语句而已
不过这样的话 还不是那么多的数据要更新??? 数据量上没什么变化
×/
[/Quote]
说的也是。
天-笑 2012-07-23
  • 打赏
  • 举报
回复


6000 这点数量,怕什么?
楼主要是实在不放心,那你就在程序,在更新数据的时候多写一句更新语句而已
不过这样的话 还不是那么多的数据要更新??? 数据量上没什么变化
×/
多难成佛 2012-07-23
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]
直接触发器,这点逻辑开销不大的,楼主放心使用触发器
[/Quote]这是订单状态表,每天大约有个6000个订单,每个订单每天至少会有6次变化(6个订单状态),这样用触发器有问题吗?
天-笑 2012-07-23
  • 打赏
  • 举报
回复
直接触发器,这点逻辑开销不大的,楼主放心使用触发器

34,594

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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