SQL SERVER 2008 Merge关键字用法与简例

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 摘自:http://blog.csdn.net/htl258/article/details/5525814 -------------------------------------------------------------------------- --  Author :...

 

摘自: http://blog.csdn.net/htl258/article/details/5525814

--------------------------------------------------------------------------

--  Author : htl258(Tony)

--  Date   : 2010-04-25 01:10:28

--  Version:Microsoft SQL Server 2008 (RTM) - 10.0.1600.22 (Intel X86)

--          Jul  9 2008 14:43:38

--          Copyright (c) 1988-2008 Microsoft Corporation

--          Developer Edition on Windows NT 5.1 <X86> (Build 2600: Service Pack 3)

--  Blog   : http://blog.csdn.net/htl258

--  Subject: SQL2008 Merge关键字用法与简例

--------------------------------------------------------------------------

--Merge 语法是对表进行插入,更新,删除这三个操作的合并。

--根据与源表联接的结果,对目标表执行插入、更新或删除操作。

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

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

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

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

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

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

 

 

--示例:

 

USE tempdb

GO

--创建表A

IF NOT OBJECT_ID('[A]') IS NULL

    DROP TABLE [A]

GO

CREATE TABLE A(ID INT,ACOL VARCHAR(10))

GO

INSERT A VALUES(1,N'A')

INSERT A VALUES(2,N'B')

INSERT A VALUES(3,N'C')

INSERT A VALUES(6,N'X') --此记录在B表中不存在,删除

GO

--创建表B

IF NOT OBJECT_ID('[B]') IS NULL

    DROP TABLE [B]

GO

CREATE TABLE B(ID INT,BCOL VARCHAR(10),XCOL VARCHAR(10))

GO

INSERT B VALUES(1,N'A',N'T')  --1的ID与A表ID匹配且指定值与A表指定值对应相同,不变

INSERT B VALUES(2,N'P',N'O')  --2和的ID与A表ID匹配,指定值与A表指定值对应不同,更新

INSERT B VALUES(3,N'P',N'N')

INSERT B VALUES(4,N'L',N'Y')  --4和的ID与A表ID匹配,指定值在A表中对应不存在,插入

INSERT B VALUES(5,N'E',N'S') 

GO

--开始合并两个表:

MERGE A --要处理的表

USING B --参照的表

ON A.ID=B.ID --关联条件

WHEN NOT MATCHED THEN INSERT VALUES(B.ID,B.BCOL) --如果要处理表没有参照表上的记录,则插入

WHEN MATCHED THEN UPDATE SET A.ACOL=B.BCOL --如果记录匹配,就更新目标表的匹配行

WHEN NOT MATCHED BY SOURCE THEN DELETE --如果要处理表的记录在参照表上不存在,则删除

OUTPUT $action, Inserted.*, Deleted.*; --相当于输出以上语句的操作记录

 

/*--result:

$action    ID          ACOL       ID          ACOL

---------- ----------- ---------- ----------- ----------

INSERT     4           L          NULL        NULL

INSERT     5           E          NULL        NULL

UPDATE     1           A          1           A

UPDATE     2           P          2           B

UPDATE     3           P          3           C

DELETE     NULL        NULL       6           X

 

(6 行受影响)

*/

--看看A表更新成什么样:

SELECT * FROM A

/*

ID          ACOL

----------- ----------

1           A

2           P

3           P

4           L

5           E

 

(5 行受影响)

*/

--再变换一个字段

MERGE A --要处理的表

USING B --参照的表

ON A.ID=B.ID --关联条件

WHEN NOT MATCHED THEN INSERT VALUES(B.ID,B.XCOL)

WHEN MATCHED THEN UPDATE SET A.ACOL=B.XCOL

WHEN NOT MATCHED BY SOURCE THEN DELETE

OUTPUT $action, Inserted.*, Deleted.*;

 

/*--result:

$action    ID          ACOL       ID          ACOL

---------- ----------- ---------- ----------- ----------

UPDATE     1           T          1           A

UPDATE     2           O          2           P

UPDATE     3           N          3           P

UPDATE     4           Y          4           L

UPDATE     5           S          5           E

 

(5 行受影响)

*/

--再看看现在的A表像什么样

SELECT * FROM A

/*

ID          ACOL

----------- ----------

1           T

2           O

3           N

4           Y

5           S

 

(5 行受影响)

*/

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
2月前
|
SQL
简单练习Microsoft SQL Server MERGE同步两个表
【10月更文挑战第13天】本文介绍了在Microsoft SQL Server中使用`MERGE`语句同步两个表的步骤。首先创建源表`SourceTable`和目标表`TargetTable`并分别插入数据,然后通过`MERGE`语句根据ID匹配行,实现更新、插入和删除操作,最后验证同步结果。此方法可根据需求调整以适应不同场景。
120 1
|
3月前
|
SQL XML Java
mybatis复习03,动态SQL,if,choose,where,set,trim标签及foreach标签的用法
文章介绍了MyBatis中动态SQL的用法,包括if、choose、where、set和trim标签,以及foreach标签的详细使用。通过实际代码示例,展示了如何根据条件动态构建查询、更新和批量插入操作的SQL语句。
mybatis复习03,动态SQL,if,choose,where,set,trim标签及foreach标签的用法
|
2月前
|
SQL 存储 数据库
SQL学习一:ACID四个特性,CURD基本操作,常用关键字,常用聚合函数,五个约束,综合题
这篇文章是关于SQL基础知识的全面介绍,包括ACID特性、CURD操作、常用关键字、聚合函数、约束以及索引的创建和使用,并通过综合题目来巩固学习。
48 1
|
3月前
|
SQL 存储 安全
SQL Server用法
SQL Server用法
97 1
|
3月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
3月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
67 1
|
4月前
|
SQL 数据处理 数据库
深入解析SQL中的MERGE语句及其重要性
【8月更文挑战第31天】
111 0
|
5月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
69 6
|
4月前
|
SQL 关系型数据库 MySQL
8、SQL高级用法
8、SQL高级用法
21 0
|
4月前
|
SQL 安全 Java
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
530 0
下一篇
DataWorks