数据库

 首页 > 数据库 > SqlServer > 解读SQL Server 2008的新语句MERGE

解读SQL Server 2008的新语句MERGE

分享到:
【字体:
导读:
         摘要: SQL Server 2008将包含用于合并两个行集(rowset)数据的新句法。根据一个源数据表对另一个数据表进行断定性的插进、更新和删除这样复杂的把持,应用新的MERGE语句,开发者用一条命令就可...

解读SQL Server 2008的新语句MERGE
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句法时,假如存在多处匹配,它会抛出一个错误。这就提示了开发者,要达到预想的目标,当前的联合条件还不够明白。



解读SQL Server 2008的新语句MERGE
分享到:
如何应用SQL Server嵌套子查询
如何应用SQL Server嵌套子查询 很多SQL Server程序员对子查询(subqueries)的应用感到困惑,尤其对于嵌套子查询(即子查询中包含一个子查询)。现在,就让我们追本溯源地探究这个标题。 有两种子查询类型:尺度和相干。尺度子查询履行一次,成果反馈给父查询。相干子查询每行履行一次,由父查询找回。在本文中,我将重点讨...
让你的MySQL数据库彻底与中文联姻
让你的MySQL数据库彻底与中文联姻 系统自带的MySQL默认字符集不是gbk,因此给数据库的推广利用以及中文程序的开发带来极大的不便,在没完没了的GBK和UTF8的转换过程中耗费了我们无数的精力以及系统的资源。经过摸索尝试解决了中文支撑标题,经验与大家分享一下。 先将让slack支撑中文,方法可以看“linuxsir.org 之Slackware...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……