SqlServer 2008+中Merge的应用
来源:互联网 发布:西门子工控机如何编程 编辑:程序博客网 时间:2024/04/30 10:10
简介:
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.源表可以是一个具体的表,也可以是一个子查询语句
实例:
--创建源表 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,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的功能并不局限于此!
- SqlServer 2008+中Merge的应用
- SQLServer 2008 Merge 的机制探讨
- merge sqlserver 2008
- SQLServer中merge关键字使用
- SQLSERVER merge的简单用法
- 浅谈SQLServer中系统表的应用
- SqlServer中关于时间函数的应用
- sqlserver分页中row_numer()函数的应用
- 浅谈SQLServer中系统表的应用
- SQLServer 中partition by的应用场景
- Sqlserver Merge
- SQLServer Merge
- Merge语句的应用
- Sas Merge语句中“in=”的应用
- 关于sqlserver 的merge 简单操作
- SqlServer 2008优化:Merge 和 Except
- SQLServer -- 事务的应用
- sqlserver 2000 中 按位与 的应用
- js+ajax+dom+php+mysql实现goolgoal suggest 效果
- Google+就是Google+社交,但真不是社交网络
- Iphone代码创建视图
- 在超级计算机里进化出智能程序,将其转移到机器人设备上。哇!智能机器人是否诞生
- u-boot启动全过程分析
- SqlServer 2008+中Merge的应用
- MVC log使用 和一些简单使用
- 找不到 Driver do Microsoft Access (*.mdb) ODBC 驱动程序的安装例程 请大神帮忙 解决问题
- 汇编helloword代码
- flexigrid 如何加上 checkbox
- 程序员学习英语三部曲
- ubuntu 8.10下修改命令行提示语言为英文
- ubuntu中安装man手册查看函数原型
- 大学阶段学习单片机,以后可以有什么用?可以做什么类型的工作?单片机发展前景怎么样?