oracle 批量修改

MERGE INTO dms_wl_info a  ----> 目标表 
USING ( SELECT c.position, SUM (c.store_qt) COUNT
FROM dms_goods_stock c
LEFT JOIN sys_office d ON d.id = C.BELONG_DEPARTMENT --> 辅助表(包含目标表需要的数据)
WHERE c.position IS NOT NULL
<if test="warehouse != null and warehouse != ''">
AND D.PARENT_IDS LIKE '%'||#{warehouse}||'%' --> 动态修改
</if>
GROUP BY c.position) b
ON (a.wl_id = b.position) --> 条件
WHEN MATCHED
THEN
UPDATE SET a.can_save_qt = A.MAX_QT - b.COUNT --> 修改语句,可以插入insert ,输出结果 output等

 需要注意的是 merge into 不能返回受影响的行数。在项目中也不是特别需要,

考虑如果需要的话可以使用 update——select 方式 或者在存储过程中调用 merge into  使用集合变量循环执行 并添加计数器返回受影响行数。

如果是insert  还可以拷贝表的镜像,然后比较表新增行数 

没有再深入研究。遇到过该问题的欢迎告知,谢谢。

 

还有一种批量修改   update_select  语句 参看 

https://www.cnblogs.com/yelanggu/p/6489515.html

 

转载于:https://www.cnblogs.com/a6948076/p/10074966.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值