SqlServer 2008+中Merge的应用
简介: ? ? ? ? ? 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可以对刚才做的改动输出: ? ? ??
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |