oracle 从一张表更新到另外一张表的方法(MERGE)

之前更新表格经常用

update aaa set (aaa.q,aaa.w) =(select bbb.q,bbb.w from bbb where bbb.e=aaa.e)的方法

后面学习了一个新的方法,MERGE法,这种写法更适合,因为对于空的值可以自定义定义其值,这样写存储过程的时候就不需要频繁的判空了

具体的写法如下

csharp 复制代码
 MERGE INTO 目标表 t1
USING 源表 t2
ON (t1.关联键 = t2.关联键)
WHEN MATCHED THEN 
UPDATE SET t1.字段 = t2.字段
WHEN NOT MATCHED THEN
 INSERT (t1.字段) VALUES ('这里的值是空的哦')

让AI模拟一个使用场景如下

csharp 复制代码
//将员工奖金表数据合并到薪资主表
MERGE INTO employee_salary tgt
USING employee_bonus src
ON (tgt.emp_id = src.emp_id AND tgt.year_month = '200109')
WHEN MATCHED THEN
  UPDATE SET 
    tgt.bonus_amount = src.amount,
    tgt.update_date = SYSDATE
  WHERE src.amount > 0 // 只更新有正奖金的记录
WHEN NOT MATCHED THEN
  INSERT (emp_id, year_month, base_salary, bonus_amount, create_date)
  VALUES (src.emp_id, '200109', 0, src.amount, SYSDATE)  //这里是没有数据的时候返回的值
  WHERE src.amount > 0;  // 只插入有正奖金的记录
相关推荐
会开花的二叉树16 小时前
实战:基于 BRPC+Etcd 打造轻量级 RPC 服务 —— 从注册到调用的完整实现
网络·数据库·c++·rpc·etcd
修炼果16 小时前
为什么使用 Redis 存储Oauth的state 参数,可有效防止 CSRF 攻击
数据库·redis·csrf
cookqq17 小时前
MongoDB源码delete分析观察者getOpObserver()->onDelete
数据库·sql·mongodb·nosql
曼曼青青草17 小时前
智能体介绍及搭建实战(智能运营)
大数据·数据库·人工智能
荷兰小香猪_0117 小时前
MongoDB数据类型与python操作
数据库·mongodb
qianmo202117 小时前
gpt-4o+deepseek+R生成热力图表
java·数据库·r语言
Zfox_17 小时前
【C++项目】微服务即时通讯系统:服务端
数据库·c++·微服务·中间件·rpc·架构·即时通讯
TDengine (老段)17 小时前
TDengine 聚合函数 HISTOGRAM 用户手册
大数据·数据库·sql·物联网·时序数据库·iot·tdengine
寻星探路18 小时前
数据库造神计划第十八天---事务(1)
数据库
BullSmall18 小时前
Doris数据库-初识
数据库·doris