Oracle 若存在则更新update ,不存在则插入insert

今天开发碰到了一个很常见的问题,就是需要根据数据库中是否存在来insert或update,以前的做法是
1.查询记录是否存在

select count(1) from table_name where ****;
2.判断
如果>=1则update table_name
如果==0则insert table_name
新学习到的方法是使用MERGE INTO语法

MERGE INTO 表名
USING 表名/视图/子查询 ON 连接条件
– 当匹配得上连接条件时
WHEN MATCHED THEN
更新、删除操作
– 当匹配不上连接条件时
WHEN NOT MATCHED THEN
更新、删除、插入操作
MERGE INTO table_name alias1
USING (table | view | sub_query) alias2
ON (join condition)
WHEN MATCHED THEN
UPDATE table_name SET col1 = col_val1, col2 = col2_val
WHEN NOT MATCHED THEN
INSERT (column_list) VALUES (column_values);
简单翻译一下
操作alias1表中的数据
通过ON 中的条件进行过滤
存在执行更新操作
不存在执行插入操作

假设studen中name字段唯一
现在的业务场景是student中有叫小明的则更新小明的信息(age)
没有叫小明的则插入小明的信息(name,age)
实现如下

merge into student stu
using (SELECT
nvl(max(student .name),0) name
FROM student
WHERE student .name= :‘小明’) s
on (stu.name=s.name)
when matched then
update set stu.age = ‘11’
when not matched then
insert ( name, age) values ( ‘小明’, ‘10’);
需要注意的地方
1.如果using中的语句什么都查不出来,那么insert是不会执行的
2.on中的条件不能作为更新列,否则会报错
3.on中的条件一定要过滤准确,否则会整表更新

目前就理解这么多

2020年4月27日记录
发现一个问题,merge into 用as别名时会报错,直接空格别名没问题

4人点赞
开发问题

作者:在简单一点
链接:https://www.jianshu.com/p/a6efb0ec640d
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 4
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值