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 settt.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 definitionCREATE 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 LOGGINGSTORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645PCTINCREASE 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,3INSERT 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 ALLSELECT 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 T1USING (<foreach collection="list" item="e"  separator="UNION ALL">SELECT #{e.id} AS ID , #{e.name} AS NAME FROM DUAL</foreach>) T2ON (T1.ID = T2.ID )WHEN MATCHED THENUPDATE SET T1.NAME = T2.NAMEWHEN NOT MATCHED THENINSERT (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的使用方法

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

无监督关键词提取算法:TF-IDF、TextRank、RAKE、YAKE、 keyBERT

TF-IDF TF-IDF是一种经典的基于统计的方法&#xff0c;TF(Term frequency)是指一个单词在一个文档中出现的次数&#xff0c;通常一个单词在一个文档中出现的次数越多说明该词越重要。IDF(Inverse document frequency)是所有文档数比上出现某单词的个数&#xff0c;通常一个单词…

建模杂谈系列236 Block Manager

说明 很久没有写了&#xff0c;总是写一半就没空往下写。这次正好有个单独的主题&#xff0c;可以写一下。 内容 1 块的分配 数据应该怎么切分和管理&#xff1f;这没有一个固定的答案&#xff0c;在我的实践中&#xff0c;我觉得一个块(Block)一万条记录是比较合理的。然后…

3分钟了解Android中稳定性测试

一、什么是Monkey Monkey在英文里的含义是猴子&#xff0c;在测试行业的学名叫“猴子测试”&#xff0c;指的是没有测试经验的人甚至是根本不懂计算机的人&#xff08;就像一只猴子&#xff09;&#xff0c;不需要知道程序的任何用户交互方面的知识&#xff0c;给他一个程序&a…

Apache OFBiz RCE漏洞复现(CVE-2023-51467)

0x01 产品简介 Apache OFBiz是一个电子商务平台,用于构建大中型企业级、跨平台、跨数据库、跨应用服务器的多层、分布式电子商务类应用系统。 0x02 漏洞概述 漏洞成因 该系统的身份验证机制存在缺陷,可能允许未授权用户通过绕过标准登录流程来获取后台访问权限。此外,在…

bilibili深入理解计算机系统笔记(3):使用C语言实现静态链接器

本文是2022年的项目笔记&#xff0c;2024年1月1日整理文件的时候发现之&#xff0c;还是决定发布出来。 Github链接&#xff1a;https://github.com/shizhengLi/csapp_bilibili 文章目录 可执行链接文件(ELF)ELF headerSection header符号表symtab二进制数如何和symtab结构成员…

关于LayUI表格重载数据问题

目的 搜索框搜索内容重载数据只显示搜索到的结果 遇到的问题 在layui官方文档里介绍的table属性有data项,但使用下列代码 table.reload(test, {data:data //data为json数据}); 时发现&#xff0c;会会重新调用table.render的url拿到原来的数据&#xff0c;并不会显示出来传…

新能源汽车冷却系统的水道管口类型有哪些?格雷希尔针对这些管口密封的快速接头有哪些?

对于新能源汽车&#xff0c;不仅电池&#xff0c;还有电机、电控、充电单元部件&#xff0c;都需要处于适宜的工作温度&#xff0c;才能维持整车的正常运行。而这些部件在运行过程中会产生大量的热量&#xff0c;如果不及时散热会对汽车的性能、寿命产生影响&#xff0c;甚至可…

css动态传参,attr的妙用

今天再做一个编辑器的功能的时候&#xff0c;发现有一段非常奇妙的代码&#xff0c;使用attr获取div标签的data-label值。 css的attr?What fuck?这又是什么鬼东西&#xff0c;emmm。 查询后官方是这么回答的&#xff1a; CSS 表达式 attr() 用来获取选择到的元素的某一 HTM…

Docker的一个简单例子(一)

文章目录 环境示例准备构建启动/停止容器更新应用分享应用 参考 环境 RHEL 9.3Docker Community 24.0.7 示例 准备 从github克隆 getting-started-app 项目&#xff1a; git clone https://github.com/docker/getting-started-app.git查看项目&#xff1a; ➜ getting-s…

Java基础02-Java编程基础

文章目录 变量&#xff08;Variables&#xff09;局部变量和成员变量局部变量&#xff08;Local Variables&#xff09;成员变量&#xff08;Instance Variables&#xff09; 标识符&#xff08;Identifiers&#xff09;八种基本数据类型原始数据类型&#xff08;Primitive Dat…

Java ArrayList解密

数组的大小是固定的&#xff0c;一旦创建的时候指定了大小&#xff0c;就不能再调整了。也就是说&#xff0c;如果数组满了&#xff0c;就不能再添加任何元素了。 ArrayList 在数组的基础上实现了自动扩容&#xff0c;并且提供了比数组更丰富的预定义方法&#xff08;各种增删改…

【Unity美术】Unity工程师对3D模型需要达到的了解【二】

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…