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;  // 只插入有正奖金的记录
相关推荐
IDOlaoluo4 小时前
Oracle 10g 安装教程(详解,从exe安装到数据库配置,附安装包)
数据库·oracle
jllws15 小时前
数据库原理及应用_数据库基础_第4章关系模型的基本理论_关系模型基本概念
数据库
曾经的三心草5 小时前
微服务的编程测评系统20-虚拟机-nginx-部署
数据库·nginx·微服务
望获linux5 小时前
【Linux基础知识系列:第一百一十六篇】使用mt进行磁带驱动管理
java·linux·运维·服务器·数据库·windows·嵌入式软件
品牌AI前线6 小时前
Few-Shot Prompting 实战:用5个例子让GPT-4学会复杂任务
服务器·数据库·人工智能
小毛驴8506 小时前
maven 常用指令
java·数据库·maven
YoungUpUp6 小时前
【SQL Server 2022】保姆级SQL Server 详细图文下载安装教程
数据库·sql·sqlserver·sql server·sql server数据库·sql server 2022·sql 数据库
知彼解己6 小时前
Redis 集群模式与高可用机制
数据库·redis·缓存
GBASE7 小时前
GBASE南大通用政企行业案例-国家电网公司“网上国网”项目
数据库