之前更新表格经常用
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; // 只插入有正奖金的记录
