本文我们主要介绍了SQL Server数据同步Merge的一个小漏洞以及解决的方案,通过以下的代码让我们来一起了解一下这一漏洞是怎么造成的以及它的解决方法吧。
假设有两个数据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的知识就介绍到这里,希望能够带给您一些收获吧!
【编辑推荐】