综合二区_欧美成人综合_欧美成人二区_a黄视频_亚洲视频在线播放_一区二区三区视频免费看

当前位置:首页 > 网站旧栏目 > 学习园地 > 程序开发教程 > 解读SQL Server2008的新语句MERGE

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

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

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

以下是引用片段:

merge [target] t
using [source] s on t.id = s.id
when matched then update t.name = s.name, t.age = s.age -- use "rowset1"
when not matched then insert values(id,name,age) -- use "rowset2"
when source not matched then delete; -- use "rowset3" 
 


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

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

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

安徽新华电脑学校专业职业规划师为你提供更多帮助【在线咨询
主站蜘蛛池模板: 91视频综合网 | 91成人短视频在线观看 | 第一色网站 | 一级片在线观看网站 | 久久久久国产一区二区三区四区 | 在线观看亚洲a | 99热在线观看精品 | 天堂一区二区三区 | 成人免费超碰 | 国产视频一区二区三区在线播放 | 午夜天堂在线视频 | 国产精品精品久久久久 | 亚洲一区二区三区精品视频 | 国产成人精品a视频一区www | 91久久精品国产91久久性色tv | 在线观看的毛片 | 免费人成在线观看 | 国产一区二区三区在线免费 | 久久九九热 | 被下了药糟蹋h文 | 国产一区二区三区视频免费 | 九九热免费视频 | 天天爽夜夜爽人人爽一区二区 | 一区二区三区四区五区中文字幕 | 52久久 | 久久久久久久久久久99 | 久久九九99| 九九九国产视频 | 91精品国产高清一区二区三区 | 91亚洲区| 久色网站 | 91免费观看网站 | 九九热免费视频 | 午夜欧美成人 | 免费成人午夜视频 | 亚洲国产一 | 91视频观看| a在线一区 | 国产三区在线观看 | 777色狠狠一区二区三区 | 一区二区在线不卡视频 |