SqlServer 2008+中Merge的应用

SqlServer 2008+中Merge的应用,第1张

概述简介:           SqlServer 2008中新增加了Merge这个DML关键字,msdn对于Merge的解释:根据与源表联结的结果,对目标表执行Insert,Update,Delete *** 作.例如:根据目标表与源表的差异,在目标表中执行执行Insert,Update,Delete *** 作,实现两个表的同步. 语法:         Mergo Into 目标表 as T         U

简介:

          sqlServer 2008中新增加了Merge这个DML关键字,msdn对于Merge的解释:根据与源表联结的结果,对目标表执行Insert,Update,Delete *** 作.例如:根据目标表与源表的差异,在目标表中执行执行Insert,Delete *** 作,实现两个表的同步.

语法:

        Mergo Into 目标表 as T

        Using 源表 as S

        ON 匹配条件

        when matched and [其它条件] then

         对源表与目标表匹配的项执行的 *** 作

        when not matched [其它条件] then 

           对源表中存在的,而目标表中不存在的匹配项执行 *** 作

         when not matched by source and [其它条件] then

           对目标表中存在的,而源表中不存在的匹配项执行 *** 作;

          注意事项 1.最后的分号必须有

                         2.源表可以是一个具体的表,也可以是一个子查询语句

实例:

        

   --创建源表   CREATE table old(ID INT,Des nvarchar(20))   --创建目标表   CREATE table New(ID INT,Des nvarchar(20))   Insert into old Values(1,'1')   Insert into old Values(2,'2') --目标表中不存在的将被插入   Insert into old Values(3,'3')   Insert into New Values(1,'匹配的将被修改')   Insert into New Values(5,'源表中不存在的将被删除')   Merge into New AS T   Using old as S   ON T.ID=S.ID   WHEN MATCHED    THEN UPDATE SET T.Des=S.Des   WHEN NOT MATCHED    THEN INSERT VALUES(S.ID,S.Des)   WHEN NOT MATCHED BY Source    THEN DELETE;

此实例实现的目标表和源表的同步.

Mergo还一个强大功能,用Output可以对刚才做的改动输出:

      

--创建源表   CREATE table old(ID INT,S.Des)   WHEN NOT MATCHED BY Source    THEN DELETE;   output $action as [Action],Inserted.ID AS 插入修改的ID,Inserted.Des as 插入修改的Des,DELETEd.ID AS 修改删除的ID,DELETED.Des as 修改删除的Des;

缺点:

        使用Merge只能更新 *** 作一个目标表         源表中不能有重复的记录         源表和目标表必须在同一个数据库中 小结:         sql Server 2008中Merge关键字的加入使得表同步有一个好的解决方案,但Mergo的功能并不局限于此!
总结

以上是内存溢出为你收集整理的SqlServer 2008+中Merge的应用全部内容,希望文章能够帮你解决SqlServer 2008+中Merge的应用所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/1179180.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-02
下一篇2022-06-02

发表评论

登录后才能评论

评论列表(0条)

    保存