SQLServer 可更新订阅数据冲突的一个原因

可更新订阅为什么有冲突?


可更新订阅中,当升级增加一个字段时,通常在发布服务器的发布数据库中增加,对表增加字段后,发布自动同步到订阅数据库中(复制架构更改=true)。但是,如果此时在订阅数据库进行DML操作,数据将不会同步到发布表中;这些差异数据在订阅表中如果一直未进行DML 操作,也就不会再次同步到发布中,存在差异。


复制配置环境:

可更新订阅事务复制

发布和订阅冲突都以订阅为准

使用排队更新

在订阅操作


冲突测试结果(以下为: 当数据存在不一致的情况下,对订阅再次操作会引起冲突,冲突策略会自动解决):


当发布数据不存在,订阅数据存在时,此时更新订阅数据:(排队更新冲突)

当发布和订阅主键相同,msrepl_tran_version不同时,此时更新订阅数据:(排队更新冲突)

以上两种情况结果:

在发布冲突,冲突表记录值都为最新值,订阅数据更新或插入到发布表中。



当发布数据不存在,订阅数据存在时,此时删除订阅数据:(排队更新冲突)

当发布和订阅主键相同,msrepl_tran_version不同时,此时删除订阅数据:(排队更新冲突)

 

以上两种情况结果:

删除操作同步到发布时冲突。

 

冲突入选方:

此行不再存在于“[dbo].[TestTab]”中。 [[dbo].[TestTab]].[qcfttabrowid] 中唯一 ID 的值是“8d335a44-36a0-432c-bba4-4979df3c804e”。

冲突落选方:

尝试删除此位置上的此数据时出现上述错误,原因可能是此删除操作违反了一个或多个约束。如果您忽略此冲突,则应通过其他方式加以解决。您可以记录此冲突的详细信息,然后将日志条目发送给系统管理员。




架构更如何防止冲突?

若要在支持更新订阅的发布中的表上进行架构更改,必须在发布服务器和订阅服务器中停止该表上的所有活动,还必须将挂起的数据更改传播到所有节点,然后才能进行架构更改。这可以确保未完成的事务不会与挂起的架构更改发生冲突。架构更改传播到所有节点后,可以在已发布的表上恢复活动。如何停止复制拓扑(复制 Transact-SQL 编程)


本人测试了一种解决方案:SQLServer 可更新订阅数据在线架构更改(增加字段)方案


参考: 事务复制的可更新订阅


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server触发器是一种特殊类型的存储过程,它会在指定的表上发生特定事件时自动执行。当表上发生更新操作时,可以通过触发器来更新数据。 触发器通常与INSERT、UPDATE和DELETE语句一起使用。当这些语句被执行时,触发器会自动调用并执行相关的操作。 在创建触发器时,需要指定触发器要绑定到的表以及要触发的事件类型(INSERT、UPDATE、DELETE)。然后,可以编写触发器的主体部分,该部分包含在触发器被调用时要执行的SQL语句。 当触发器绑定的表上发生与触发器事件类型匹配的操作时,触发器会自动执行。在执行过程中,可以使用内置的Inserted和Deleted表来引用被修改的数据。Inserted表包含插入或更新操作所添加或修改的行,而Deleted表包含删除或更新操作所删除或修改的行。 通过在触发器的主体部分编写更新操作的SQL语句,可以实现对表数据更新。这些更新可以是根据触发器事件导致的数据更改,也可以是根据其他表或计算逻辑生成的数据。 使用触发器更新数据的好处是,在数据变更时自动执行相关操作,而无需手动干预。这可以保证数据一致性和完整性,并减少人为错误的可能性。 需要注意的是,使用触发器更新数据时,应谨慎操作,避免造成循环触发和性能问题。同时,触发器的相关操作应经过充分的测试和验证,确保其正常运行并达到预期的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值