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 小时前
向量化和列式存储
大数据·sql·向量化
懒虫虫~19 小时前
通过内存去重替换SQL中distinct,优化SQL查询效率
java·sql·慢sql治理
逛逛GitHub19 小时前
1 个神级智能问数工具,刚开源就 1500 Star 了。
sql·github
Huhbbjs20 小时前
SQL 核心概念与实践总结
开发语言·数据库·sql
咋吃都不胖lyh20 小时前
SQL-字符串函数、数值函数、日期函数
sql
sensenlin9120 小时前
Mybatis中SQL全大写或全小写影响执行性能吗
数据库·sql·mybatis
xqlily1 天前
SQL 数据库简介
数据库·sql
森林-1 天前
MyBatis 从入门到精通(第三篇)—— 动态 SQL、关联查询与查询缓存
sql·缓存·mybatis
小虾米vivian1 天前
达梦:将sql通过shell脚本的方式放在后台执行
服务器·数据库·sql
武昌库里写JAVA1 天前
Mac下Python3安装
java·vue.js·spring boot·sql·学习