解读SQL Server 2008的新语句MERGE


SQL Server 2008将包含用于合并两个行集(rowset)数据的新句法。根据一个源数据表对另一个数据表进行确定性的插入、更新和删除这样复杂的操作,运用新的MERGE语句,开发者用一条命令就可以完成。

  对两个表进行信息同步时,有三步操作要进行。首先要处理任何需要插入目标数据表的新行。其次是处理需要更新的已存在的行。最后要删除不再使用的旧行。这个过程中需要维护大量重复的逻辑,并可能导致微妙的错误。

  Bob Beauchemin讨论了MERGE语句,这个语句将上述的多个操作步骤合并成单一语句。他给出了如下的例子:

  以下是引用片段:  

merge[target]t
  using[source]sont.id=s.id
  whenmatchedthenupdatet.name=s.name,t.age=s.age--use"rowset1"
  whennotmatchedtheninsertvalues(id,name,age)--use"rowset2"
  whensourcenotmatchedthendelete;--use"rowset3"

  如你所见,具体操作是根据后面的联合(join)的解析结果来确定的。在这个例子中,如果目标和源数据表有匹配的行,就实行更新操作。如果没有,就实行插入或者删除操作来使目标数据表和源数据表保持一致。

  这个新句法的一个美妙之处是它在处理更新时的确定性。在使用标准的UPDATE句法和联合时,可能有超过一个源行跟目标行匹配。在这种情况下,无法预料更新操作会采用哪个源行的数据。

  而当使用MERGE句法时,如果存在多处匹配,它会抛出一个错误。这就提醒了开发者,要达到预想的目标,当前的联合条件还不够明确。



相关阅读:
CSS教程:网页中英文字体的设置
javascript[对象.属性]集锦(建议加入精华区
将jQuery应用于login页面的问题及解决
DHTML Slide Show script图片轮换
oracle实现递归查询
Linux系统内核 2.6.28 五大特性
网页开发人员必须知道的10个不常用HTML标签
JavaScript在ASP中实现掩码文本框
Vista用Defrag命令整理磁盘碎片
学习WEB标准心得:网页重构的思路
如何为Exchange服务重建IIS虚拟目录
CentOS中安装商业主机控制面板DTC(Domain Technologie Control)
新浪滑门技术
让XHTML与HTML兼容
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 变了,散了,算了…… 赠给全世界GIRL作文1000字 美丽的东方之珠 幽默早安短信 关于端午节日记:端午节快乐 校园文化艺术节暨“六一”文艺汇演活动方案 流光的纤蓝——专访90后作家黄洁 那个梦作文650字 多功能衣服作文400字 在高速公路公司任职大会上的讲话 美丽的雪花 如何提高社交能力 春暖花开--灵魂深处的桃花源 中岳嵩山导游词 关于军训的励志诗歌节选 与书桌一起走过的日子作文900字 盐务局述职报告 印刷求职信范文 小白菜交朋友作文600字 在宗教座谈会上的发言 小学六年级作文600字:在灾难面前 小学四年级作文900字:小枫叶 游黄帝陵 广货街随想 保险营销演讲稿 会议新闻稿范文 老师,我想对您说... ...作文100字 妈妈的“易容术” 与岁月同等心跳 认真对待优势 本科教学工作水平评估欢迎仪式讲话稿 也许在某一天 解放思想大讨论活动查摆问题剖析材料 忆旧游寄谯郡元参军 小学六年级作文600字:美丽的城南风景区 《太平轮》观后感 写尊重的优美句子 克服自己的缺点 宁静致远话得失 小明滚出去系列笑话第八季:你过来,我保证不打你 医院大逃亡作文450字 史·马记天官设 年轻的妈妈作文250字 我们班的坏小子作文750字 昆仑之巅----献给奋斗在高原上的战士们 xx县物价局党支部关于召开民主生活会的情况汇报 奉和思黯自题南庄见示兼呈梦得 快乐主持人作文400字 不知足才能常乐650字 农村入党申请书怎样写 给妈妈的一顿早餐

Copyright © 2016 phpStudy |