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

相关推荐
惜.己3 小时前
MyBatis中一对多关系的两种处理方法
java·开发语言·后端·sql·mysql·mybatis·idea
终末圆3 小时前
MyBatis动态SQL中的`if`标签使用【后端 19】
java·数据结构·数据库·sql·算法·spring·mybatis
andrew_12195 小时前
腾讯 IEG 游戏前沿技术 一面复盘
java·redis·sql·面试
andrew_12195 小时前
腾讯 IEG 游戏前沿技术 二面复盘
后端·sql·面试
Aa1345176502517 小时前
c#中使用sql防注入方式写入数据
数据库·sql·c#
OceanSky618 小时前
Mybatis中sql数组为空判断
数据库·sql·mybatis·数组判空
Data 31719 小时前
经典sql题(七)查找直播间最大在线人数
大数据·数据库·数据仓库·sql
胡耀超21 小时前
MyBatis-Plus插入优化:降低IO操作的策略与实践
sql·spring·mybatis
Data 3171 天前
经典sql题(二)求连续登录最多天数用户
大数据·数据库·数据仓库·sql·mysql
小王是个弟弟1 天前
HQL-计算不一样的 MUV
数据库·hive·sql