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

一、需求描述

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

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

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

二、Merge Into

MERGE (oracle.com)icon-default.png?t=N7T8https://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 THENUPDATE table_name SET col1 = col_val1, col2 = col2_val
WHEN NOT MATCHED THENINSERT (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 thenUPDATE 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

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

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

相关文章

solr-lucene的解释

什么是solr-lucene Solr是一个基于Apache Lucene的开源搜索平台。Lucene是一个开源的全文搜索引擎库,它提供了一个简单而强大的API,用于索引和搜索文档。Solr通过在Lucene的基础上构建一个更高级的搜索平台,为用户提供了更丰富的功能和易于使…

Unity VisionOS开发流程

Unity开发环境 Unity Pro, Unity Enterprise and Unity Industry 国际版 Mac Unity Editor(Apple silicon) visionOS Build Support (experimental) 实验版 Unity 2022.3.11f1 NOTE: 国际版与国服版Pro账通用,需要激活Pro的许可证。官方模板v0.6.2,非Pro版本会打…

灵途科技助力家电智能创新

从智能家电到个护健康,科技无时无刻不在刷新我们对智慧生活的认知,我们也从未像今天这样近距离贴近智慧生活的朴素本质——传感技术。灵途科技专注光电感知技术,持续为智能家电客户提供成熟的全方位感知解决方案。步入发展第八年,…

I2C系列(三):软件模拟I2C读写24C02

一.目标 PC 端的串口调试软件通过 RS-485 与单片机通信,控制单片机利用软件模拟 I2C 总线对 EEPROM(24C02) 进行任意读写。 二.硬件简述 2.1 24C02硬件参数 24C02器件地址为0x50,存储容量为256字节,存储单元地址位数…

DMA知识

提示:文章 文章目录 前言一、背景二、 2.1 2.2 总结 前言 前期疑问: 本文目标: 一、背景 2024年3月26日23:32:43 今天看了DMA存储器到存储器的DMA传输和存储器到外设的DMA实验,在keil仿真可以看到效果。还没有在protues和开发…

【文献分享】PY-Nodes 程序:使用 Nelder-Mead 的单纯形法在材料中搜索节点的从头开始的 Python 代码

题目:PY-Nodes: An ab-initio python code for searching nodes in a material using Nelder-Mead’s simplex approach 链接:Redirecting PY-Nodes:使用 Nelder-Mead 的单纯形法在材料中搜索节点的从头开始的 Python 代码 随着拓扑半金…

说说webpack的热更新是如何做到的?原理是什么?

文章目录 一、是什么二、实现原理三、总结参考文献 一、是什么 HMR全称 Hot Module Replacement,可以理解为模块热替换,指在应用程序运行过程中,替换、添加、删除模块,而无需重新刷新整个应用 例如,我们在应用运行过…

echarts 柱形图如何让其中一个柱子的颜色跟其他柱子不同

如何让其中一个柱子的颜色跟其他柱子不同 series: [{data: [120,// 使用对象的形式, value代表当前值, itemStyle设置样式{value: 200,itemStyle: {color: #a90000}},150,80,70,110,130],type: bar}]设置单个柱子颜色: 柱形图单个柱子颜色: https://e…

yolov5+pyside6+登录+用户管理目标检测可视化源码

一、软件简介 这是基于yolov5目标检测实现的源码,提供了用户登录功能界面; 用户需要输入正确的用户名和密码才可以登录。如果是超级管理员,可以修改普通用户的信息,并且在检测界面的右上角显示【管理用户】按钮。 支持图片、视频、…

系统架构设计-构建系统应用

1. 系统架构目标与设计原则 在设计系统架构时,我们的目标是确保系统具有以下特点: 可靠性:系统能够持续稳定运行,保证业务可用性。可伸缩性:系统能够根据负载变化自动扩展或收缩,以应对不同的流量需求。容…

盒子模型与样式排版

目录 前言: 1.先带大家复习一下前面学习过的知识: 1.1在外面写前端过程中怎么找到标签元素的选择器: 1.1.1通配符选择器: 1.1.2标签选择器: 1.1.3class选择器: 1.1.4id选择器: 1.2样式表写法: 1.2.1.行内样式表: 1.2.2.内部样式表 : 1.2.3.外部样式表: 2.块元素基…

DaisyDisk for mac 苹果电脑磁盘清理工具

DaisyDisk for Mac是一款直观易用的磁盘空间分析工具,专为Mac用户设计,旨在帮助他们快速识别和管理磁盘上的文件与文件夹,从而释放存储空间。 软件下载:DaisyDisk for mac 激活版 DaisyDisk采用独特的可视化界面,将磁盘…