欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【解读SQL Server2008的新语句MERGE】,下面是详细的分享!
解读SQL Server2008的新语句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句法时,如果存在多处匹配,它会抛出一个错误。这就提醒了开发者,要达到预想的目标,当前的联合条件还不够明确。
本文收集整理自互联网,若您是原文作者,请来信更改作者及出处Post#chinaz.com(把#改为@)
以上所分享的是关于解读SQL Server2008的新语句MERGE,下面是编辑为你推荐的有价值的用户互动:
相关问题:sql server 2008 merge matched判定条件
答:SQL Server 2008 开始支持 MERGE语句 -- 源表CREATE TABLE test_from (id INT, val VARCHAR(20));-- 目标表CREATE TABLE test_to (id INT, val VARCHAR(20));-- 插入源表INSERT INTO test_from VALUES (1, 'A');INSERT INTO test_from VALUES (2... >>详细
相关问题:SQL Server2005的sql语句跟SQL Server2008有什么不...
答:SQL 2008 在 SQL 2005 的基础上, 又增加了一些新的特性。 例如 SQL 2008 增加了 新的数据类型。 DATE , TIME , 与 DATETIME2 SQL 2008 还增加了 MERGE INTO 的语句, 也就是处理 那种 存在就更新, 不存在就插入 的业务逻辑 还有一些其他的特... >>详细
相关问题:关于SQL Server 2008 数据插入及更新的问题
答:你这个语句是在同一个窗口下执行了两次,还是在不同窗口下执行的? 语法没错误,是不是use指向的数据库有问题? >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
