From 2a2f094b447c604ca2884922586df32f0665b81c Mon Sep 17 00:00:00 2001
From: zwl <1051256694@qq.com>
Date: 星期三, 29 四月 2026 09:27:44 +0800
Subject: [PATCH] 双伸出库改成订单出库 完成转订单

---
 src/main/java/com/zy/asrs/task/handler/WorkMastHandler.java |   36 +++++++++++++++++++++---------------
 1 files changed, 21 insertions(+), 15 deletions(-)

diff --git a/src/main/java/com/zy/asrs/task/handler/WorkMastHandler.java b/src/main/java/com/zy/asrs/task/handler/WorkMastHandler.java
index f7ce891..9c12b61 100644
--- a/src/main/java/com/zy/asrs/task/handler/WorkMastHandler.java
+++ b/src/main/java/com/zy/asrs/task/handler/WorkMastHandler.java
@@ -539,14 +539,8 @@
                     }
                     for (WrkDetl wrkDetl : wrkDetls101) {
                         // 鏇存柊璁㈠崟瀹屾垚鏁伴噺
-                        OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectItem(wrkDetl.getOrderNo(), wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getBrand(), wrkDetl.getStandby1(), wrkDetl.getStandby2(), wrkDetl.getStandby3(),
-                                wrkDetl.getBoxType1(), wrkDetl.getBoxType2(), wrkDetl.getBoxType3());
-                        if (orderDetlPakout == null) {
-                            orderDetlPakout = orderDetlPakoutService.selectItem(wrkDetl.getOrderNo(), wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getBrand(), wrkDetl.getStandby1(), wrkDetl.getStandby2(), wrkDetl.getStandby3(),
-                                    wrkDetl.getBoxType1(), wrkDetl.getBoxType2(), wrkDetl.getBoxType3());
-                        }
                         try {
-                            if (!increasePakoutOrderQty(wrkMast, wrkDetl, orderDetlPakout)) {
+                            if (!increasePakoutOrderQty(wrkMast, wrkDetl)) {
                                 TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
                                 return FAIL.setMsg("鍏ㄦ澘鍑哄簱 ===>> 鏇存柊璁㈠崟瀹屾垚鏁伴噺澶辫触; [workNo=" + wrkMast.getWrkNo() + "],[locNo=" + wrkMast.getSourceLocNo() + "]");
                             }
@@ -592,10 +586,8 @@
                             }
                         }
                         // 鏇存柊璁㈠崟瀹屾垚鏁伴噺
-                        OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectItem(wrkDetl.getOrderNo(), wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getBrand(), wrkDetl.getStandby1(), wrkDetl.getStandby2(), wrkDetl.getStandby3(),
-                                wrkDetl.getBoxType1(), wrkDetl.getBoxType2(), wrkDetl.getBoxType3());
                         try {
-                            if (!increasePakoutOrderQty(wrkMast, wrkDetl, orderDetlPakout)) {
+                            if (!increasePakoutOrderQty(wrkMast, wrkDetl)) {
                                 TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
                                 return FAIL.setMsg("骞舵澘閫斾腑鎹℃枡 ===>> 鏇存柊璁㈠崟瀹屾垚鏁伴噺澶辫触; [workNo=" + wrkMast.getWrkNo() + "],[locNo=" + wrkMast.getSourceLocNo() + "]");
                             }
@@ -658,22 +650,36 @@
      * 鏂板鐨勫欢杩熷嚭搴撹鍗曟槑缁嗘寜 pallet_id 淇濆瓨鎺ュ彛鎵樼洏鍙凤紝鍥犳浼樺厛浣跨敤 orderNo + palletId 绮剧‘鍥炲啓锛�
      * 濡傛灉鏄巻鍙茶鍗曟垨鏃ф暟鎹病鏈� pallet_id锛屽垯閫�鍥炲師鏉ョ殑鐗╂枡/鎵规/澶囩敤瀛楁鍖归厤鏂瑰紡銆�
      */
-    private boolean increasePakoutOrderQty(WrkMast wrkMast, WrkDetl wrkDetl, OrderDetlPakout matchedOrderDetl) {
+    private boolean increasePakoutOrderQty(WrkMast wrkMast, WrkDetl wrkDetl) {
+        if (wrkDetl == null || Cools.isEmpty(wrkDetl.getOrderNo())) {
+            return true;
+        }
         String palletId = null;
-        if (wrkDetl != null && !Cools.isEmpty(wrkDetl.getZpallet())) {
+        if (!Cools.isEmpty(wrkDetl.getZpallet())) {
             palletId = wrkDetl.getZpallet();
         } else if (wrkMast != null) {
             palletId = wrkMast.getBarcode();
         }
+        // stationId > 600 鐨勫欢杩熷嚭搴撹鍗曟槸涓�鎵樼洏涓�琛屾槑缁嗭紱鍚屼竴璁㈠崟銆佺墿鏂欍�佹壒娆°�佽繘浠撶紪鍙蜂笅浼氭湁澶氳銆�
+        // 鍥犳瀹屾垚鍥炲啓蹇呴』浼樺厛鐢� orderNo + palletId 绮剧‘瀹氫綅锛屽惁鍒欐棫鐨勭墿鏂欑淮搴︽煡璇細鍛戒腑澶氳銆�
         if (!Cools.isEmpty(palletId)
                 && orderDetlPakoutService.increaseQtyByOrderNoAndPallet(wrkDetl.getOrderNo(), palletId, wrkDetl.getAnfme())) {
             return true;
         }
+        // 鍏煎鍘嗗彶璁㈠崟锛氭棫鏁版嵁鍙兘娌℃湁 pallet_id锛屽彧鑳介��鍥炲師鏉ョ殑鐗╂枡/鎵规/澶囩敤瀛楁鍖归厤銆�
+        // 杩欓噷涓嶅啀璋冪敤鎵归噺 update SQL锛岃�屾槸鍏堝彇涓�鏉℃槑缁嗗悗鎸� id 鏇存柊锛岄伩鍏嶉噸澶嶆槑缁嗘椂鎶婂琛� qty 涓�璧峰姞涓娿��
+        OrderDetlPakout matchedOrderDetl = orderDetlPakoutService.selectItem(wrkDetl.getOrderNo(), wrkDetl.getMatnr(),
+                wrkDetl.getBatch(), wrkDetl.getBrand(), wrkDetl.getStandby1(), wrkDetl.getStandby2(), wrkDetl.getStandby3(),
+                wrkDetl.getBoxType1(), wrkDetl.getBoxType2(), wrkDetl.getBoxType3());
         if (Cools.isEmpty(matchedOrderDetl)) {
             return true;
         }
-        return orderDetlPakoutService.increaseQtyByOrderNo(wrkDetl.getOrderNo(), wrkDetl.getMatnr(),
-                matchedOrderDetl.getBatch(), wrkDetl.getBrand(), wrkDetl.getStandby1(), wrkDetl.getStandby2(), wrkDetl.getStandby3(),
-                wrkDetl.getBoxType1(), wrkDetl.getBoxType2(), wrkDetl.getBoxType3(), wrkDetl.getAnfme());
+        matchedOrderDetl.setQty(safeDouble(matchedOrderDetl.getQty()) + safeDouble(wrkDetl.getAnfme()));
+        matchedOrderDetl.setUpdateTime(new Date());
+        return orderDetlPakoutService.updateById(matchedOrderDetl);
+    }
+
+    private double safeDouble(Double value) {
+        return value == null ? 0.0D : value;
     }
 }

--
Gitblit v1.9.1