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

相关推荐
小锅巴1231 小时前
百度测开面经(分类版)
数据库·分类·数据挖掘
芒果要切1 小时前
Redis 使用场景
数据库·redis·缓存
全栈工程师修炼指南1 小时前
DBA | Oracle RMAN 实战:物理备份与数据恢复全解析
数据库·oracle·dba
现在,此刻1 小时前
clickhouse和pgSql跨库查询方案对比
数据库·sql·clickhouse·性能优化
while(1){yan}1 小时前
数据库的基本操作
数据库·oracle
翻斗花园牛图图-1 小时前
MySQL——库的操作
数据库·mysql
大猫会长1 小时前
supabase备份数据库中某个schema的方法
数据库·oracle
-指短琴长-2 小时前
MySQL快速入门——内置函数
android·数据库·mysql
小码过河.4 小时前
告别 mysqldump 痛点!用 mydumper 实现 MySQL 高效备份与恢复
数据库·mysql
TDengine (老段)4 小时前
从“数据堆场”到“智能底座”:TDengine IDMP如何统一数据语言
大数据·数据库·物联网·时序数据库·tdengine