快捷搜索:

解读SQL Server2008的新语句MERGE

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

对两个表进行信息同步时,有三步操作要进行。首先要处置惩罚任何必要插入目标数据表的新行。其次是处置惩罚必要更新的已存在的行。着末要删除不再应用的旧行。这个历程中必要掩护大年夜量重复的逻辑,并可能导致奥妙的差错。 中国站长.站

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

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"Chinaz~com

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

中.国.站.长.站

这个新句法的一个美妙之处是它在处置惩罚更新时切实着实定性。在应用标准的UPDATE句法和联应时,可能有跨越一个源行跟目标行匹配。在这种环境下,无法预感更新操作会采纳哪个源行的数据。 中国站.长.站

而当应用MERGE句法时,假如存在多处匹配,它会抛出一个差错。这就提醒了开拓者,要达到预想的目标,当前的联合前提还不敷明确。

中国站.长.站

中.国站长站

您可能还会对下面的文章感兴趣: