ORACLE数据有则更新无则新增的SQL

现在是北京时间:2022/11/17 0:52

少有的写代码到现在。遇到了个有趣的事儿就索性记录下来。

不知为何我常用的MyBatisPlus中的一个API(saveorupdate)用不了了,看了报错懒得去弄,于是打算手写一个功能相同的SQL。

SQL如下:

BEGIN
UPDATE 表名
SET 字段名=#{值}
WHERE 字段名=#{值};
IF
SQL%NOTFOUND THEN
INSERT INTO 表名 (字段名1,字段名2,字段名3)
VALUES (
#{值1},
#{值2},
#{值3}
);
END IF;
END;

解读一下呢,如果update语句能执行就执行,执行不了也不会抛错而是执行下面的插入语句。

这里就是SQL%NOTFOUND的用法啦,如前面的SQL语句为NOTFOUND则执行后面的,除了这个还有SQL%FOUND。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值