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;  // 只插入有正奖金的记录
相关推荐
jiayou6417 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩3 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3504 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB5 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶5 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构