解析SQL Server 2008中的新语句:MERGE

数据库 SQL Server
SQL Server 2008是SQL Server数据库众多版本之一,本文为大家介绍SQL Server 2008的新语句,即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句法时,假如存在多处匹配,它会抛出一个错误。这就需要开发者主意,要达到预想的目标,当前的联合条件还不够十分明确。

【编辑推荐】

  1. SQL Server 2008中的数据压缩功能
  2. SQL Server 2008数据库引擎中几个重要的Discontinued Feature
  3. SQL Server 2008基于策略的管理

 

责任编辑:迎迎 来源: 赛迪网
相关推荐

2010-10-14 09:32:52

SQL Server

2010-07-19 12:47:04

SQL Server

2011-08-19 10:40:27

SQL Server Merge命令

2011-03-29 11:21:47

SQL Server 商业智能

2011-05-24 13:33:45

2009-04-16 17:44:31

2009-04-16 18:15:19

动作审核审核活动SQL Server

2010-06-28 16:56:27

SQL Server

2010-12-06 09:26:23

SQL Server

2010-11-12 13:08:36

动态sql语句

2011-07-07 17:06:03

SQL Server

2012-04-06 10:13:08

SQLSQL Server

2012-04-16 09:55:38

SQL Server

2009-06-22 10:22:57

SQL Server

2013-03-13 09:53:50

SQL Server

2009-04-16 17:03:12

报表开发工具报表制作SQL Server

2021-05-28 07:36:18

MySQLWhereHive

2009-04-16 17:59:25

细粒度权限

2009-04-16 18:07:39

2010-09-13 10:21:26

sql server2
点赞
收藏

51CTO技术栈公众号