Oracle 同表更新或插入

一、需求

现在有一张count表,存在两个字段name和count,分别记录输入的名称以及出现的次数

要求输入的名称若在表中未存在,则新增,并初始化count的值为1

若在表中已经存在,则将count值加一

二、实现

2.1 方案一

在处理前统计name出现的次数,若大于一,则修改,否则为新增

2.2 方案二

根据上面的逻辑,使用plsql实现

sql 复制代码
DECLARE
  v_count NUMBER;
  v_name char(20);
BEGIN
  v_name:='a';  

  SELECT COUNT(*)
  INTO v_count
  FROM (SELECT name, COUNT(*) as count
        FROM count
        GROUP BY name)
  WHERE name = v_name;
  
  IF v_count >= 1 THEN
    UPDATE count
    SET count = count + 1
    WHERE name = v_name;
  ELSE
    INSERT INTO count values(v_name,1);
  END IF;
END;

更新:此时往表中插入一条已经存在的name a,只需修改v_name 的值为'a'

新增:此时往表中插入一条不存在的name c,修改v_name 的值为'c'

2.3 方案三

根据上面的逻辑,使用merge into实现

sql 复制代码
merge into count c1
using ( select count(*) count from count c2 where c2.name = 'a' ) c3
on (c3.count > 0)
when matched then
    update set c1.count = c1.count + 1 where c1.name = 'a'
when not matched then
    insert values('a',1) ;

现在清空数据表,新增一行数据a

再次点击执行,则执行修改逻辑

三、参考

merge into 对同一张表进行更新和插入_oracle merge同表-CSDN博客

PLSQL 基础语法(二) - 掘金 (juejin.cn)

相关推荐
qq_12498707534 分钟前
基于SSM框架的智能密室逃脱信息管理系统(源码+论文+部署+安装)
java·大数据·人工智能·spring boot·后端·毕业设计·计算机毕业设计
掉鱼的猫16 分钟前
从 Chat 到 Agent:Solon AI 带你进入“行动派”大模型时代
后端
vivo互联网技术23 分钟前
vivo 微服务架构实践之 Dubbo 性能优化
java·后端·微服务·中间件·dubbo
仙俊红24 分钟前
Spring 构造器注入 vs 字段注入
java·后端·spring
0和1的舞者28 分钟前
Spring 事务核心知识点全梳理(编程式 + 声明式 + 注解详解)
java·后端·spring
风象南32 分钟前
Spring Boot 中使用 JSONPath 高效处理 JSON 数据
后端
用户695619440371 小时前
PageOffice最简集成代码(SpringMVC)
java·后端
程序员爱钓鱼1 小时前
Node.js 编程实战:博客系统 —— 用户注册登录与文章管理
前端·后端·node.js
掘金者阿豪1 小时前
在Java项目中,如果没有使用Redis相关的代码或依赖,但在 `application.yaml` 配置文件中配置了Redis参数,项目启动时是否会报错
后端