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可以快捷的实现

相关推荐
f***019319 分钟前
clickhouse-介绍、安装、数据类型、sql
数据库·sql·clickhouse
大飞记Python26 分钟前
【2025全攻略】PyCharm专业版 / 社区版如何打开.db 数据库文件
数据库·python·sql·pycharm
f***281435 分钟前
SQL-Server链接服务器访问Oracle数据
服务器·sql·oracle
曹牧3 小时前
Oracle中ROW_NUMBER() OVER()
java·数据库·sql
6***A6635 小时前
SQL 插入数据详解
服务器·数据库·sql
e***28295 小时前
mybatisPlus打印sql配置
数据库·sql
V***u4535 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
稚辉君.MCA_P8_Java6 小时前
在PostgreSQL中,将整数(int)转换为字符串
数据库·sql·postgresql
Hello.Reader6 小时前
Flink SQL 语言从 DDL 到 DML,再到关键字与数据类型
sql·flink·linq
mn_kw7 小时前
Spark SQL CBO(基于成本的优化器)参数深度解析
前端·sql·spark