SQL Server 2008 的 Transact-SQL 语言增强(2)

来源:csdn        2010-01-25 07:35:53        点击:
收藏本页:


顶一下

作者:张洪举 Microsoft MVP 应用于:SQL Server 2008日期:2008/9/1 6.MERGE 语句在 SQL Server 2008 中,可以使用 MERGE 语句在一条语句中根据与源表联接的结果对

SQL Server 2008 的 Transact-SQL 语言增强(2) 由Linux系统中文网(Linux521.com)编辑收集整理,除Linux521注明原创文章外,其版权归原作者所有。如果您在学习中遇到问题欢迎在下面的评论中留言,我们会尽全力解答您的问题。
作者:张洪举 Microsoft MVP

应用于:SQL Server 2008

日期:2008/9/1



6.MERGE 语句

在 SQL Server 2008 中,可以使用 MERGE 语句在一条语句中根据与源表联接的结果对目标表执行 INSERT、UPDATE 或 DELETE 操作。如:使用一个语句有条件地在单个目标表中插入或更新行,如果目标表中存在相应行,则更新一个或多个列;否则,会将数据插入新行。使用该语句还可以同步两个表,根据与源数据的差别在目标表中插入、更新或删除行。

MERGE 语法包括如下五个主要子句:

MERGE 子句用于指定作为插入、更新或删除操作目标的表或视图。

USING 子句用于指定要与目标联接的数据源。

ON 子句用于指定决定目标与源的匹配位置的联接条件。

WHEN 子句用于根据 ON 子句的结果指定要执行的操作。

OUTPUT 子句针对更新、插入或删除的目标对象中的每一行返回一行。

其完整的语法格式如下:

[ WITH [,...n] ]

MERGE

[ TOP ( expression ) [ PERCENT ] ]

[ INTO ] target_table [ WITH ( ) ] [ [ AS ] table_alias ]

USING

ON

[ WHEN MATCHED [ AND ]

THEN ]

[ WHEN NOT MATCHED [ BY TARGET ] [ AND ]

THEN ]

[ WHEN NOT MATCHED BY SOURCE [ AND ]

THEN ]

[ ]

[ OPTION ( [ ,...n ] ) ]

使用下面的语句创建两个表:

USE AdventureWorks;

GO

IF OBJECT_ID (N'dbo.Purchases', N'U') IS NOT NULL

DROP TABLE dbo.Purchases;
内容来源:www.linux 521.com Linux系统中文网
《Linux系统中文网》欢迎原创作者投稿,请先注册成为会员,然后在后台 相应的栏目里提交你的文章,注意填写好相关信息点“保存”。我们将在24小时之内审核完毕。

 1/5    1 2 3 4 5 下一页 尾页
我要评论: SQL Server 2008 的 Transact-SQL 语言增强(2)
请务必尊重网上道德,遵守中华人民共和国的各项法律法规,承担一切因您的行为而直接或间接导致的法律责任。本站管理人员有权删除留言中的任意内容。

昵称  验证码  
热门
相关