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

相关推荐
前进的李工1 天前
SQL聚合函数与分组查询详解
数据库·sql·mysql
lkbhua莱克瓦241 天前
基础-函数
开发语言·数据库·笔记·sql·mysql·函数
今天有个Bug1 天前
【计算机毕业设计】流浪动物救助平台 - SpringBoot+Vue
sql·mysql·spring·vue·毕业设计·课程设计
l1t1 天前
一个postgresql奇怪慢查询现象的原因和解决
数据库·sql·postgresql·性能优化
lkbhua莱克瓦241 天前
基础-SQL-DML
开发语言·数据库·笔记·sql·mysql
l1t2 天前
PostgreSQL Distinct On 关键字的用法
数据库·sql·postgresql
2401_832298102 天前
云服务器 vs 传统物理服务器,企业该如何选择?
sql
ha_lydms2 天前
4、Spark 函数_m/n/o/p/q/r
大数据·数据库·python·sql·spark·数据处理·dataworks
lkbhua莱克瓦242 天前
基础-约束
android·开发语言·数据库·笔记·sql·mysql·约束
falldeep2 天前
LeetCode高频SQL50题总结
数据结构·数据库·sql·算法·leetcode·职场和发展