详解 SQL Merge关键字

Merge关键字是一个神奇的DML关键字。它在SQL Server 2008被引入,它能将Insert,Update,Delete简单的并为一句。MSDN对于Merge的解释非常的短小精悍:”根据与源表联接的结果,对目标表执行插入、更新或删除操作。

MERGE的语法

MERGE INTO target_table

USING source_table

ON condition

WHEN MATCHED THEN

operation

WHEN NOT MATCHED THEN

operation;

注意:其中最后语句分号不可以省略,且源表既可以是一个表也可以是一个子查询语句。

MERGE的用法

merge无法多次更新同一行,也无法更新和删除同一行

当源表和目标表不匹配时:

若数据是源表有目标表没有,则进行插入操作;

若数据是源表没有而目标表有,则进行更新或者删除数据操作

当源表和目标表匹配时:

进行更新操作或者删除操作

MERGE的使用场景

数据同步

数据转换

基于源表对目标表做INSERT,UPDATE,DELETE操作

我们常用的是第三种场景

MERGE使用限制

在 MERGE MATCHED 操作中,只能允许执行 UPDATE 或者 DELETE 语句。

在 MERGE NOT MATCHED 操作中,只允许执行 INSERT 语句。

一个 MERGE语句中出现的MATCHED操作,只能出现一次 UPDATE 或者 DELETE 语句,否则就会出现下面的错误: An action of type ‘WHEN MATCHED’ cannot appear more than once in a ‘UPDATE’ clause of a MERGE statement.

MERGE示例

下面我们通过一个示例来介绍一下该如何使用MERGE,我们以Customers表和Orders表为例。数据如下:

SQL中Merge的用法SQL中Merge的用法
SQL中Merge的用法SQL中Merge的用法

Q:当Customers表里的客户有购买商品,我们就更新一下他们的下单时间,将他们的下单时间往后推迟一小时,如果客户没有购买商品,那么我们就将这些客户的信息插入到订单表里。

根据上面的要求我们可以这样写SQL:

MERGE INTO Orders O
--确定目标表Orders
USING Customers C ON C.客户ID=O.客户ID  
--从源表Customers确定关联条件 C.客户ID=O.客户ID
WHEN MATCHED  
--当匹配时对目标表的订单日期执行更新操作
THEN UPDATE SET O.订单日期=DATEADD(HOUR,1,O.订单日期)
WHEN NOT MATCHED BY TARGET
--当不匹配时对目标表进行插入操作
THEN INSERT (客户ID,员工ID,订单日期,发货ID)
VALUES (C.客户ID,NULL,NULL,NULL)

我们看一下Orders表里的结果:

SQL中Merge的用法SQL中Merge的用法

我们发现与Customers表里匹配上的订单日期被修改了,订单日期往后推迟了一小时,而没有匹配上的在订单表尾部增加了几行记录。这就是MERGE的实际应用了。

OUTPUT子句

MERGE还能与OUTPUT一起使用,可以将刚刚做过变动的数据进行输出,我们以上面的示例为基础,进行示范。

MERGE INTO Orders O
--确定目标表Orders
USING Customers C ON C.客户ID=O.客户ID
--从源表Customers确定关联条件 C.客户ID=O.客户ID
WHEN MATCHED  
--当匹配时对目标表的订单日期执行更新操作
THEN UPDATE SET O.订单日期=DATEADD(HOUR,1,O.订单日期)
WHEN NOT MATCHED BY TARGET
--当不匹配时对目标表进行插入操作
THEN INSERT (客户ID,员工ID,订单日期,发货ID)
VALUES (C.客户ID,NULL,NULL,NULL)
OUTPUT $action AS [ACTION],Inserted.订单日期 ,
Inserted.客户ID,Inserted.发货ID,Inserted.员工ID
--用OUTPUT输出刚刚变动过的数据

执行上述语句结果如下:

SQL中Merge的用法SQL中Merge的用法

从上图我们看到,执行的动作都是更新,这里的动作只有UPDATE和DELETE,插入也属于更新,此外我们看到订单日期又往后推迟了一小时,是因为我们又一次执行了往后增加一小时的更新操作,其他的字段没变。

总结

MERGE功能比较丰富,以上我们只是简单介绍了一些常用功能,还有其他一些用法,有兴趣的可以搜索一下并动手尝试。在我们要对表做多种操作时,这种写法不仅可以节省代码,而且有时候还可以提高执行效率。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/221813.html<

(0)
运维的头像运维
上一篇2025-04-15 05:12
下一篇 2025-04-15 05:13

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注