本文我们主要介绍了SQL Server数据同步Merge的一个小漏洞以及解决的方案,通过以下的代码让我们来一起了解一下这一漏洞是怎么造成的以及它的解决方法吧。
成都创新互联长期为上千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为富县企业提供专业的网站设计、成都网站设计,富县网站改版等技术服务。拥有十余年丰富建站经验和众多成功案例,为您定制开发。
假设有两个数据a.Name NVarchar(40)和b.Name Varchar(40),代码如下:
- MERGE a AS TARGET
- USING (
- SELECT
- id,name
- FROM b
- ) AS SOURCE ON (TARGET.[id] = SOURCE.[id])
- WHEN MATCHED AND CHECKSUM(TARGET.Name)!= CHECKSUM(CONVERT(NVARCHAR(40),SOURCE.[Name])) THEN
- UPDATE SET TARGET.[Name] = SOURCE.[Name],
- WHEN NOT MATCHED BY TARGET THEN
- INSERT (
- [id]
- ,[Name]
- ) VALUES(
- SOURCE.[ID]
- ,SOURCE.[Name]
- )
- WHEN NOT MATCHED BY SOURCE THEN
- Delete ....
当b.name 以“-” 结束,如 “test-” 这种情况,merge不起作用。其他情况都还好。
需要把
- CHECKSUM(TARGET.Name)!= CHECKSUM(CONVERT(NVARCHAR(40),SOURCE.[Name]))
变成
- CHECKSUM(CONVERT(NVARCHAR(40),TARGET.Name))!= CHECKSUM(SOURCE.[Name])
后才可以同步。
关于SQL Server数据同步Merge的知识就介绍到这里,希望能够带给您一些收获吧!
【编辑推荐】
标题名称:SQL Server数据同步Merge的一个BUG及解决方法
URL标题:http://www.shufengxianlan.com/qtweb/news7/9507.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联