Oracle merge into 语句用法 Oracle merge into 批量更新 关联更新 批量修改 关联修改

Oracle merge into 语句用法 Oracle merge into 批量更新 关联更新 批量修改 关联修改

一、概述

        在开发任务中,遇到一个需求,同一批次的名单;根据一定的条件判断是否存在,若存在,则进行更新操作;若不存在,进行插入操作。实现方法有两种:

        1. java代码中,使用业务逻辑来判断是否存在,存在,修改;不存在,添加。

        2、由于使用的Oracle数据库,可以使用merge into语句来实现批量的添加、修改操作

        本文将记录和讲解merge into 语句的使用mybatis中使用 merge into 语句

二、代码示例

        1、 merge into 语法规则

MERGE INTO target_table tt  -- 目标表
USING source_table st -- 关联表
ON (tt.id = st.id AND tt.age = st.age ) -- 是否唯一条件,可以是多个 

WHEN MATCHED AND tt.name <> st.name THEN  -- 1、满足条件--带额外条件
WHEN MATCHED THEN  -- 2、满足条件-- 不带额外条件
UPDATE SET  -- 执行更新操作,注意没有 表名 update set
    tt.name = st.name ,
    tt.age = st.age 

[ WHEN NOT MATCHED THEN ]  -- 3、不满足条件, 可选,非必须语句
INSERT (id, name) VALUES (st.id, st.name);  -- 执行添加操作,注意没有表名 insert

        2.1、创建2张表

-- WUDI.USER_TARGET definition

CREATE TABLE "WUDI"."USER_TARGET" 
   (    "ID" VARCHAR2(100), 
    "NAME" VARCHAR2(100), 
    "ADDR" VARCHAR2(100)
   ) SEGMENT CREATION IMMEDIATE 
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING
  STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT)
  TABLESPACE "WUDI" ;

COMMENT ON COLUMN WUDI.USER_TARGET.ID IS '主键';
COMMENT ON COLUMN WUDI.USER_TARGET.NAME IS '名字';
COMMENT ON COLUMN WUDI.USER_TARGET.ADDR IS '地址';

--- USER_SOURCE 表创建过程略

        2.2、插入数据

-- 1.1、 USER_TARGET 初始化数据 ID= 1,2,3

INSERT INTO WUDI.USER_TARGET(ID, NAME, ADDR) VALUES('1', 'TARGET=1', '');
INSERT INTO WUDI.USER_TARGET(ID, NAME, ADDR) VALUES('2', 'TARGET=2', '');
INSERT INTO WUDI.USER_TARGET(ID, NAME, ADDR) VALUES('3', 'TARGET=3', NULL);

-- 2.1、 USER_SOURCE 初始化数据 ID= 3,4,5
INSERT INTO WUDI.USER_SOURCE (ID, NAME, ADDR) VALUES('3', 'SOURCE=3', NULL);
INSERT INTO WUDI.USER_SOURCE (ID, NAME, ADDR) VALUES('4', 'SOURCE=4', NULL);
INSERT INTO WUDI.USER_SOURCE (ID, NAME, ADDR) VALUES('5', 'SOURCE=5', NULL);

        2.2.1、USER_TARGET 表数据如下

        2.2.2、USER_SOURCE 表数据如下

        2.3、使用merge into 更新

--  MERGE INTO : USER_SOURCE 数据 合并到 USER_TARGET  , 存在修改;不存在添加
MERGE INTO USER_TARGET T1 
USING USER_SOURCE T2 
ON (T1.ID = T2.ID )
WHEN MATCHED THEN 
    UPDATE SET T1.NAME = T2.NAME
WHEN NOT MATCHED THEN 
INSERT (ID,NAME) VALUES(T2.ID,T2.NAME) ; 

        2.3.1、merge into 更新后 USER_TARGET 表数据如下

        2.4、使用merge into 更新 --- 子查询

-- 3.2、不存在 ID=7,8 添加数据
MERGE INTO USER_TARGET T1 
USING (
    SELECT 7 AS ID , 'SOURCE=7' AS NAME  FROM DUAL 
    UNION ALL
    SELECT 8 AS ID , 'SOURCE=8' AS NAME  FROM DUAL 
)T2
ON (T1.ID = T2.ID)
WHEN NOT MATCHED THEN 
INSERT (ID,NAME) VALUES(T2.ID,T2.NAME) ; 
        2.4.1、merge into 更新---子查询 USER_TARGET 表数据如下

        3、MyBatis中使用示例

<update id="updateBatch" parameterType="list">
   MERGE INTO USER_TARGET T1
      USING (
          <foreach collection="list" item="e"  separator="UNION ALL">
            SELECT #{e.id} AS ID , #{e.name} AS NAME FROM DUAL
         </foreach>
         ) T2
      ON (T1.ID = T2.ID )
      WHEN MATCHED THEN
         UPDATE SET T1.NAME = T2.NAME
      WHEN NOT MATCHED THEN
         INSERT (ID,NAME) VALUES(T2.ID,T2.NAME) ;
</update>

        4、merge into NULL值问题

        在使用merge into语句时,若遇到 on 中遇到的两个字段值,都是null值的情况,不会执行 when matched then 语句,会一直执行 when not matched then ... , 也就 on条件中 null=null 的条件是false , 如本示例中 ,会一直执行 when not matched then 。

ON (T1.ID = T2.ID AND T1.ADDR = T2.ADDR )
MERGE INTO USER_TARGET T1 
USING (
   SELECT * FROM USER_SOURCE a WHERE a.id ='3'
)T2
-- ON 条件不满足,会执行insert插入数据
ON (T1.ID = T2.ID AND T1.ADDR=  T2.ADDR)
WHEN MATCHED THEN 
    UPDATE SET T1.NAME = T2.NAME
WHEN NOT MATCHED THEN 
INSERT (ID,NAME) VALUES(T2.ID,T2.NAME) ; 

        4.1、COALESCE函数解决 merge into null 值问题

        使用 COALESCE 函数,可以将NULL值转换为某个固定的值,来进行判断,这样遇到 NULL=NULL的情况,可以转换为 1=1 ,这样就可以避免NULL值的时候,判断情况不准确的问题。

MERGE INTO USER_TARGET T1 
USING (
   SELECT * FROM USER_SOURCE a WHERE a.id ='3'
)T2
-- COALESCE 函数,将NULL值转换为1
ON (T1.ID = T2.ID AND COALESCE(T1.ADDR,'1') = COALESCE( T2.ADDR,'1'))
WHEN MATCHED THEN 
    UPDATE SET T1.NAME = T2.NAME
WHEN NOT MATCHED THEN 
INSERT (ID,NAME) VALUES(T2.ID,T2.NAME) ; 

三、总结

        1、on后面的关联条件成立时:

        on后面的关联条件成立时: WHEN MATCHED THEN ,可以 update、delete 。

        2、on后面的关联条件不成立时:

        on后面的关联条件不成立时: WHEN NOT MATCHED THEN ,可以insert

        3、只会改变 目标表数据 MERGE INTO TABLE , 不会改变 源表数据 USING TABLE

        4、USING TBALE 支持: 视图 view 、表table 、子查询 subQuery

        5、WHEN MATCHED THEN 和 WHEN NOT MATCHED THEN , 可以二选其一,也可以同时存在。

参考资料:

Oracle中merge into的使用方法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/283047.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ES6之Reflect详解

✨ 专栏介绍 在现代Web开发中&#xff0c;JavaScript已经成为了不可或缺的一部分。它不仅可以为网页增加交互性和动态性&#xff0c;还可以在后端开发中使用Node.js构建高效的服务器端应用程序。作为一种灵活且易学的脚本语言&#xff0c;JavaScript具有广泛的应用场景&#x…

MySQL基础入门(二)

多表内容 一对多 这个内容是黑马的入门问题&#xff0c;可以带大家思考一下这个怎么设计 我们要知道一个岗位可以对应很多用户&#xff0c;而一个用户只能对应一个岗位&#xff0c;这就属于一对多的类型 那么我们需要怎么将他们进行关联呢&#xff1f; 现在我们可以通过一个…

Visual Transformer (ViT)模型详解

1 Vit简介 1.1 Vit的由来 ViT是2020年Google团队提出的将Transformer应用在图像分类的模型&#xff0c;虽然不是第一篇将transformer应用在视觉任务的论文&#xff0c;但是因为其模型“简单”且效果好&#xff0c;可扩展性强&#xff08;scalable&#xff0c;模型越大效果越好…

strlen的自定义函数的三种实现方法

文章目录 一&#xff0c;概要二&#xff0c;题目三&#xff0c;方法1&#xff0c;方法一2&#xff0c;方法二3&#xff0c;方法三 四&#xff0c;总结 一&#xff0c;概要 在求字符串长度的时候我们会遇到求解字符串的长度&#xff0c;此时我们想到的是strlen&#xff0c;头文件…

如何跨系统构建docker镜像?

转载说明&#xff1a;如果您喜欢这篇文章并打算转载它&#xff0c;请私信作者取得授权。感谢您喜爱本文&#xff0c;请文明转载&#xff0c;谢谢。 1. 前言 docker镜像有基于amd64系统的&#xff0c;也有基于arm64系统的。 前段时间用了一个在x86_64的centos7服务器上构建的i…

SpringBoot自动配置原理和自定义启动器

1、自动配置的原理 项目在加载上下文时&#xff0c;会根据SpringBootApplication注解运行。该注解中有一个CompoentScan注解&#xff0c;会扫描和加载当前启动类所在的目录&#xff0c;以及所有的子目录&#xff1b;还有一个是EnableAutoConfiguration注解&#xff0c;这个注解…

huggingface的tokenizer解读

文章目录 前言一、huggingface的tokenizer含义1、含义2、整体概括 二、加载lmsys/vicuna-7b-v1.5模型的tokenizer三、调用tokernizer方法四、字符串的tokens应用1、tokenizer应用2、tokenizer进行token分词(tokenizer.tokenize)3、tokens转模型识别ids(tokenizer.convert_token…

Centos7:Jenkins+gitlab+node项目启动(2)

Centos7&#xff1a;Jenkinsgitlabnode项目启动(1) Centos7&#xff1a;Jenkinsgitlabnode项目启动(1)-CSDN博客 Centos7&#xff1a;Jenkinsgitlabnode项目启动(2) Centos7&#xff1a;Jenkinsgitlabnode项目启动(2)-CSDN博客 Centos7&#xff1a;Jenkinsgitlabnode项目启…

数据结构【线性表篇】(三)

数据结构【线性表篇】(三&#xff09; 文章目录 数据结构【线性表篇】(三&#xff09;前言为什么突然想学算法了&#xff1f;为什么选择码蹄集作为刷题软件&#xff1f; 目录一、双链表二、循环链表三、静态链表 结语 前言 为什么突然想学算法了&#xff1f; > 用较为“官方…

回溯法求不等式的所有整数解

这份代码本来是用来解决这个问题的 但是&#xff0c;修改之后即可用来解决任意多个xi组成的满足不等式的整数解 这里用真代码而不是伪代码来表示 源代码&#xff1a; #include<iostream> using namespace std; const int N1010; int p,q,r,goal,n; int cnt,sum,MIN; i…

ES6之生成器(Generator)

✨ 专栏介绍 在现代Web开发中&#xff0c;JavaScript已经成为了不可或缺的一部分。它不仅可以为网页增加交互性和动态性&#xff0c;还可以在后端开发中使用Node.js构建高效的服务器端应用程序。作为一种灵活且易学的脚本语言&#xff0c;JavaScript具有广泛的应用场景&#x…

挑战Python100题(9)

100+ Python challenging programming exercises 9 Question 81 Please write a program to randomly print a integer number between 7 and 15 inclusive. Hints: Use random.randrange() to a random integer in a given range. 请编写一个程序,随机打印一个介于7和15之间…

Java学习,一文掌握Java之SpringBoot框架学习文集(1)

&#x1f3c6;作者简介&#xff0c;普修罗双战士&#xff0c;一直追求不断学习和成长&#xff0c;在技术的道路上持续探索和实践。 &#x1f3c6;多年互联网行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &#x1f389;欢迎 &#x1f44d;点赞✍评论…

2021-06-25 51蛋骗鸡按键切合LED

缘由ISIS 7 Professional_有问必答-CSDN问答 #include "REG52.h" sbit K1 P3^0; sbit K2 P3^1; sbit K3 P3^2; sbit K4 P3^3; void main() {unsigned char Xd0,xz0,cs0;unsigned int wei0;P1255;while(1){if(K10&&Xd0){P10;while(K10);}if(K20&&…

【2023 CCF 大数据与计算智能大赛】基于TPU平台实现超分辨率重建模型部署 基于预训练ESPCN的轻量化图像超分辨率模型TPU部署方案

2023 CCF 大数据与计算智能大赛 《基于TPU平台实现超分辨率重建模型部署》 作品名&#xff1a;基于预训练ESPCN的轻量化图像超分辨率模型TPU部署方案 队伍名&#xff1a;Absofastlutely 蒋松儒 计算机科学与技术系 硕士 南京大学 中国-江苏 kahsoltqq.com 吕欢欢 计算…

AI产品经理 - 如何做一款软硬协同AI产品

【背景】从0做一款软硬协同的AI产品&#xff0c;以智能医药保温箱 1.以智能医药保温箱 2.调研定义市场方向 地点&#xff1a;医药、实验室 场景&#xff1a;长宽高/装箱/运输/实验室 3.需求挖掘 4.如何进行软硬件AI产品工作 软硬件产品设计&#xff1a;功能/硬件外观设计、…

《数据库开发实践》之存储过程【知识点罗列+例题演练】

一、什么是存储过程&#xff1f; 1.概念理解&#xff1a; 存储过程是一组为了完成特定功能的SQL语句集。通过组成SQL语句和控制语句&#xff0c;提供一种封装任务的方法。因此在创建编译好某个存储过程后&#xff0c;因为存储过程中有可执行操作的sql语句&#xff0c;用户可以…

OFDM——PAPR减小

文章目录 前言一、PAPR 减小二、MATLAB 仿真1、OFDM 信号的 CCDF①、MATLAB 源码②、仿真结果 2、单载波基带/通频带信号的 PAPR①、MATLAB 源码②、仿真结果 3、时域 OFDM 信号和幅度分布①、MATLAB 源码②、仿真结果 4、Chu 序列和 IEEE802.16e 前导的 PAPR①、MATLAB 源码②…

模型 KANO卡诺模型

本系列文章 主要是 分享 思维模型&#xff0c;涉及各个领域&#xff0c;重在提升认知。需求分析。 1 卡诺模型的应用 1.1 餐厅需求分析故事 假设你经营一家餐厅&#xff0c;你想了解客户对你的服务质量的满意度。你可以使用卡诺模型来收集客户的反馈&#xff0c;并分析客户的…

MySQL的日志管理以及备份和恢复

MySQL日志管理 mysql的日志默认保存位置为/usr/local/mysql/data vim /etc/my.cnf #开启二进制日志功能 vim /etc/my.cnf [mysqld]##错误日志&#xff0c;用来记录当MySQL启动、停止或运行时发生的错误信息&#xff0c;默认已开启 log-error/usr/local/mysql/data/mysql_…