Oracle中实现根据条件对数据的增删改操作——Merge Into

一、需求描述

在我们进行项目开发的过程中,会遇到这样的场景,需要根据某个条件对数据进行增、删、改的操作;遇到这种情况我们有2种方法进行解决:

方法一:①查询指定条件;②根据查询出的指定条件结果在执行对应的增、删、改操作;

方法二:直接使用Merge Into语句根据条件进行对应的增、删、改操作;

二、Merge Into

MERGE (oracle.com)https://docs.oracle.com/en/database/oracle/oracle-database/19/sqlrf/MERGE.html#GUID-5692CCB7-24D9-4C0E-81A7-A22436DC968F

2.1、Merge Into的语法

复制代码
Merge Into语法:

MERGE INTO table|view A
USING (table | view | sub_query) B
ON (condition)
WHEN MATCHED THEN
  UPDATE table_name SET col1 = col_val1, col2 = col2_val
WHEN NOT MATCHED THEN
  INSERT (column_list) VALUES (column_values);

该语法的含义是:

操作A表或视图的数据,其操作数据的来源为B中数据的记录数,通过ON括号中的条件进行过滤,当A和B中的数据通过on条件进行过滤后,如果存在就执行更新操作,如果不存在就执行插入操作。

2.2、Merge Into示例

现有grade和grade2这2个表,现在需要实现:查询grade表的人名与grade2中人名相同则将grade表中对应相同人名的年龄全部更新为26;否则在grade中插入grade没有但是grade2表有的人名信息:

复制代码
merge into "grade" A
using (SELECT * from "grade2") B
ON (A."name"=B."name") 
when matched then
	UPDATE set A."age"=22
when not matched then 
	insert("id","name","course","score","sex","age") values(10,B."name",'语文',B."chinese",'女',27);

三、使用Merge时的3个注意事项

3.1、注意事项一

如果using中的语句查询不出来数据,是不会执行insert方法的,因为这个语法是根据using 中的查询数据进行判断的。

3.2、注意事项二

Merge into语句写的时候on 中的条件记得过滤准确,不然可能会执行全表更新.

3.3、注意事项三

Merge into语句ON中的条件不能用于更新操作列,不然会报错:ORA-38104

相关推荐
睡不醒男孩0308234 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐6 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪6 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通7 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..7 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29148 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜8 小时前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊9 小时前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅10 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 202310 小时前
Vue复习
linux·服务器·数据库