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