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

相关推荐
后端小张1 小时前
Redis 执行 Lua,能保证原子性吗?
数据库·redis·缓存
离开地球表面_991 小时前
索引失效?查询结果不正确?原来都是隐式转换惹的祸
数据库·后端·mysql
lipviolet1 小时前
Redis系列---Redission分布式锁
数据库·redis·分布式
Zhen (Evan) Wang1 小时前
.NET 6 API + Dapper + SQL Server 2014
数据库·c#·.net
毕设木哥2 小时前
25届计算机专业毕设选题推荐-基于python+Django协调过滤的新闻推荐系统
大数据·服务器·数据库·python·django·毕业设计·课程设计
洛阳泰山2 小时前
Llamaindex 使用过程中的常见问题 (FAQ)
java·服务器·数据库·python·llm·rag·llamaindex
没有名字的小羊2 小时前
Linux基础命令——账户简单管理
linux·运维·服务器·网络·数据库
单字叶2 小时前
MySQL数据库管理
数据库·mysql
ID_云泽2 小时前
MVCC机制解析:提升数据库并发性能的关键
数据库·mvcc
小灰灰是码农...2 小时前
MySQL的数据库课程设计的基本步骤和考虑因素
数据库