SQL 高级语法 MERGE INTO

根据与源表相联接的结果,对目标表进行插入、更新、删除等操作。 例如,对目标表,如果源表存在的数据则更新,没有的则插入,就可以使用MEREG进行同步。

基本语法

复制代码
MERGE INTO target_table
USING source_table
ON condition
WHEN MATCHED THEN 
XXX
WHEN NOT MATCHED THEN 
XXX

这里的Source table 不限于单独的表格,也可以是子查询的内容

示例

复制代码
INSERT tbl_A (col, col2)
SELECT col, col2
FROM tbl_B
WHERE NOT EXISTS (SELECT col FROM tbl_A A2 WHERE A2.col = tbl_B.col);

上面的SQL是为了向 tbl_A 中插入 tbl_B 含有的,但是 tbl_A 不包含的col

改为MERGE可以写为

复制代码
MERGE INTO tbl_A  t  
    USING tbl_B v  
    ON t.col = v.col  
    WHEN MATCHED THEN   
        UPDATE SET y.c2 = v.c2  
    WHEN NOT MATCHED THEN  
        INSERT (col, col2) VALUES (v.c1, v.c2);

(这里为了展示更多的选项,加多了一句UPDATE)

当一个表需要依托于另一个表进行更新操作的时候,使用MERGE可以快捷的实现

相关推荐
编程、小哥哥5 小时前
oracle值sql记录
数据库·sql·oracle
hkfkn8 小时前
SQL刷题日志(day2)
数据库·sql
songx_9916 小时前
数据库10(代码相关语句)
数据库·sql
caihuayuan418 小时前
Redis奇幻之旅(三)1.redis客户端与服务端
java·大数据·sql·spring·课程设计
King.62420 小时前
从 SQL2API 到 Text2API:开启数据应用开发的新征程
大数据·开发语言·数据库·sql·低代码
pwzs21 小时前
理解最左前缀原则:联合索引命中规则全解析(含流程图)
数据库·sql·mysql
Always_away1 天前
数据库系统概论|第三章:关系数据库标准语言SQL—课程笔记4
数据库·笔记·sql·学习
在下_诸葛1 天前
狂神SQL学习笔记六:列的数据类型讲解
笔记·sql·学习
weixin_307779131 天前
Azure Synapse Dedicated SQL pool里大型表对大型表分批合并数据的策略
数据仓库·sql·microsoft·azure
随记1231 天前
Microsoft SQL Server Management 一键删除数据库所有外键
数据库·sql·sqlserver