当使用多个WHEN MATCHED语句时,它们全部执行还是仅执行一个?

当使用多个WHEN MATCHED语句时,它们全部执行还是仅执行一个?,第1张

当使用多个WHEN MATCHED语句时,它们全部执行还是仅执行一个?

要回答您的问题,是的,它将只进行一次比赛然后中断。但是,如果您希望逻辑允许在更新中进行条件匹配,则该

CASE
语句对此非常有用。

像这样的例子:

MERGE INTO YourTableUSING (VALUES (1, 1, NULL), (0, 0, NULL), (0, 1, NULL), (1, 0, NULL))       T2 (a2,b2,c2)ON a = a2 AND b = b2WHEN MATCHED  THEN    UPDATe SET c =       CASE         WHEN a = 1 THEN 0        WHEN b = 1 THEN 1        ELSE NULL      END        WHEN NOT MATCHED THEN    INSERT (a, b) VALUES (a2, b2);SELECT * FROM YourTable ORDER BY a,b;
  • SQL小提琴演示

结果:

A   B   C--------------0   0   (null)0   1   11   0   01   1   0


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5618415.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-15
下一篇 2022-12-15

发表评论

登录后才能评论

评论列表(0条)

保存