zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    【滚动数组】 dp poj 1036
    【多重背包】 poj 2392
    【树状数组】 poj 2352
    【矩阵压缩】 poj 1050
    【八皇后问题】 回溯算法
    【矩阵加速】 矩阵 快速幂
    【快速幂】 模板
    【二分图】 判断是否是二分图
    Struts2标签库
    Struts2之获取ServletAPI
  • 原文地址:https://www.cnblogs.com/a6948076/p/10074966.html
Copyright © 2011-2022 走看看