<转>Merge关键字用法与简例

本文介绍了一个使用SQL MERGE语句来同步两个表(A和B)数据的过程。通过具体实例展示了如何进行插入、更新及删除操作,并输出了操作记录,最后验证了A表更新后的状态。

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')  --1IDAID匹配且指定值与A表指定值对应相同,不变

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

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

INSERT B VALUES(4,N'L',N'Y')  --4和的IDAID匹配,指定值在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 行受影响)

*/

转载于:https://www.cnblogs.com/lizhe88/archive/2011/01/20/1940379.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值