OceanBase系列---【oracle模式的存在即更新,不存在即新增的merge into用法】

一、需求

复制代码
写一个存在即更新,不存在即新增的sql。表里没有id,是一个联合主键,所以为了防止并发下的安全问题,使用sql的merge into来实现。

二、分析

复制代码
MERGE INTO: 这是 Oracle 模式下处理 Upsert(更新或插入)最标准、最高效的语法。
USING (...): 这里构造了一个虚拟数据源 S,里面包含了你当前要处理的客户号和员工号。
ON (...): 这是判断依据,只要表中已经有了这个组合 (CUST_NO + EMP_ID),就会进入 WHEN MATCHED 分支。
并发安全: OceanBase 的 MERGE INTO 语句在底层实现了原子性操作,在高并发场景下也能保证计数准确,不会出现多线程冲突导致数据不一致的问题。

三、案例

sql 复制代码
CREATE TABLE CALL_RECORD (
    CUST_NO     VARCHAR2(50) NOT NULL,
    EMP_ID      VARCHAR2(50) NOT NULL,
    CALL_COUNT  NUMBER DEFAULT 0,
    CREATE_TIME DATE DEFAULT SYSDATE,
    UPDATE_TIME DATE DEFAULT SYSDATE,
    -- 将联合字段设为主键,自动隐含了唯一约束
    CONSTRAINT PK_OUTBOUND_CALL_STATS PRIMARY KEY (CUST_NO, EMP_ID)
);


#把下面的'C001','E88'替换成占位符即可
MERGE INTO OUTBOUND_CALL_STATS T
USING (SELECT 'C001' AS INPUT_CUST, 'E888' AS INPUT_EMP FROM DUAL) S
ON (T.CUST_NO = S.INPUT_CUST AND T.EMP_ID = S.INPUT_EMP)
WHEN MATCHED THEN
    -- 记录存在:次数加1,更新时间
    UPDATE SET 
        T.CALL_COUNT = T.CALL_COUNT + 1,
        T.UPDATE_TIME = SYSDATE
WHEN NOT MATCHED THEN
    -- 记录不存在:插入新数据,次数初始化为1
    INSERT (CUST_NO, EMP_ID, CALL_COUNT, CREATE_TIME, UPDATE_TIME)
    VALUES (S.INPUT_CUST, S.INPUT_EMP, 1, SYSDATE, SYSDATE);
相关推荐
m0_613856294 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios7945 小时前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1375 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
收获不止数据库5 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
小宇的天下5 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
bqq198610265 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
Elastic 中国社区官方博客6 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索
互联网推荐官6 小时前
上海软件定制开发全流程拆解:需求分析、技术选型与交付管理的工程实践
大数据·数据库·需求分析
专注API从业者7 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
大迪deblog7 小时前
系统架构师-数据库-数据库设计
数据库·oracle·系统架构