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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM