设为首页 加入收藏

TOP

SqlServer 2008+中Merge的应用
2014-11-24 08:26:21 来源: 作者: 【 】 浏览:0
Tags:SqlServer 2008 Merge 应用

简介:

SqlServer 2008中新增加了Merge这个DML关键字,msdn对于Merge的解释:根据与源表联结的结果,对目标表执行Insert,Update,Delete操作.例如:根据目标表与源表的差异,在目标表中执行执行Insert,Update,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.源表可以是一个具体的表,也可以是一个子查询语句

实例:

[sql]
--创建源表
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可以对刚才做的改动输出:

[sql]

--创建源表 
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;
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的功能并不局限于此!


作者 softkexin

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇SQL server 2012 新特性 下一篇Oracle数据表结构/字段/类型/大小..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Redis压力测试实战 - (2025-12-27 09:20:24)
·高并发一上来,微服 (2025-12-27 09:20:21)
·Redis 高可用架构深 (2025-12-27 09:20:18)
·Linux 系统监控 的完 (2025-12-27 08:52:29)
·一口气总结,25 个 L (2025-12-27 08:52:27)