Oracle中Merge Using用法

MERGE INTO 是 Oracle 独有的 DML (数据操纵语言) 语法,也叫**「合并更新 / 插入语句」,是 Oracle 最强大的语法之一,专门解决 「单条 SQL 完成 插入 + 更新 两个操作」**的业务需求,替代了传统的 先SELECT判断 → 再INSERT/UPDATE 这种低效且有并发风险的写法。

复制代码
MERGE INTO 目标表 目标表别名
USING 数据源 数据源别名
ON (匹配条件)
-- 匹配成功时执行【更新】,可写多个字段更新
WHEN MATCHED THEN 
    UPDATE SET 目标表别名.字段1=数据源别名.字段1, 目标表别名.字段2=数据源别名.字段2 [WHERE 更新过滤条件]
-- 匹配失败时执行【插入】,字段和值一一对应
WHEN NOT MATCHED THEN 
    INSERT (目标表字段1, 目标表字段2, ...) VALUES (数据源别名.字段1, 数据源别名.字段2, ...) [WHERE 插入过滤条件];

1.MERGE INTO 是整体关键字,必须和 USING 成对出现,缺一不可;

2.ON(匹配条件) 是核心判断依据,决定了走「更新」还是「插入」;

3.WHEN MATCHED 和 WHEN NOT MATCHED 分支至少写一个,也可以两个都写(你的业务就是两个都写,最常用);

4.两个分支是互斥的:永远只会执行其中一个,不会同时触发;

5.执行效率极高:一次 SQL 请求完成两个逻辑,比 SELECT+INSERT/UPDATE 少一次数据库交互,工业系统海量数据入库必用。

相关推荐
JAVA面经实录9172 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫7122 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
Mr.Daozhi3 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_803 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体
大鹏说大话3 小时前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库
夏贰四4 小时前
数据建模工具如何筑牢数据根基?数据建模工具怎样落实标准体系?
数据库·数学建模·数据建模工具
程序猿阿伟5 小时前
《一套完整方法论:搞定图形应用的Docker镜像优化》
数据库·docker·容器
二等饼干~za8986686 小时前
geo优化源码开发搭建技术分享
大数据·网络·数据库·人工智能·音视频
jnrjian6 小时前
CDB 中某个PDB的datafile 丢失 没有备份过也可恢复 需要来回切换CDB PDB
oracle
数据库小学妹6 小时前
HTAP混合负载架构:如何用一个数据库同时搞定交易和分析
数据库·经验分享·架构·dba