解析SQL2008数据库中的新语句:MERGE_SQL SERVER数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

解析SQL数据库 2008中的新语句:MERGE

作者:黑客防线网安SQL维护基地 来源:黑客防线网安SQL维护基地 浏览次数:0

本篇关键词:语句数据库解析数据
黑客防线网安网讯:  Microsoft SQL Server 2008将包含用于合并两个行集(rowset)数据的新句法。根据一个源数据表对另一个数据表进行确定性的插入、更新和删除这样复杂的操作,运用新的MERGE语句,开发者只需...

  Microsoft 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句法时,假如存在多处匹配,它会抛出一个错误。这就需要开发者主意,要达到预想的目标,当前的联合条件还不够十分明确。

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-9609-1.html
网站维护教程更新时间:2012-03-21 02:22:42  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer