From 24a8bab265ca39cfe7bac4c276cedd7ff1bbe405 Mon Sep 17 00:00:00 2001
From: zhangchao <zc857179121@qq.com>
Date: 星期六, 31 八月 2024 18:30:30 +0800
Subject: [PATCH] 调整

---
 src/main/java/com/zy/asrs/service/impl/OrderServiceImpl.java |   67 +++++++++++++++++++++++++++------
 1 files changed, 54 insertions(+), 13 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/OrderServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OrderServiceImpl.java
index 53b9cea..dc8534d 100644
--- a/src/main/java/com/zy/asrs/service/impl/OrderServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OrderServiceImpl.java
@@ -79,19 +79,59 @@
                     throw new CoolException("閲嶆暣鍑哄簱璁㈠崟銆恛rderNo = " + order.getOrderNo() + "銆戞槑缁嗗け璐�");
                 }
                 List<WrkDetl> wrkDetls = wrkDetlService.selectAndLogByOrderNo(orderNo);
-                for (WrkDetl wrkDetl : wrkDetls) {
-                    OrderDetl orderDetl = new OrderDetl();
-                    orderDetl.sync(wrkDetl);
-                    orderDetl.setQty(orderDetl.getAnfme());
-                    orderDetl.setOrderId(order.getId());
-                    orderDetl.setOrderNo(orderNo);
-                    orderDetl.setStatus(1);
-                    orderDetl.setCreateTime(order.getCreateTime());
-                    orderDetl.setCreateBy(order.getCreateBy());
-                    orderDetl.setUpdateTime(order.getUpdateTime());
-                    orderDetl.setUpdateBy(order.getUpdateBy());
-                    if (!orderDetlService.insert(orderDetl)) {
-                        throw new CoolException("閲嶆暣鍑哄簱璁㈠崟銆恛rderNo = " + order.getOrderNo() + "銆戞槑缁嗗け璐�");
+                if (orderDetls.size() == wrkDetls.size()) {
+                    for (WrkDetl wrkDetl : wrkDetls) {
+                        OrderDetl orderDetl = new OrderDetl();
+                        orderDetl.sync(wrkDetl);
+                        orderDetl.setQty(orderDetl.getAnfme());
+                        orderDetl.setOrderId(order.getId());
+                        orderDetl.setOrderNo(orderNo);
+                        orderDetl.setStatus(1);
+                        orderDetl.setCreateTime(order.getCreateTime());
+                        orderDetl.setCreateBy(order.getCreateBy());
+                        orderDetl.setUpdateTime(order.getUpdateTime());
+                        orderDetl.setUpdateBy(order.getUpdateBy());
+                        if (!orderDetlService.insert(orderDetl)) {
+                            throw new CoolException("閲嶆暣鍑哄簱璁㈠崟銆恛rderNo = " + order.getOrderNo() + "銆戞槑缁嗗け璐�");
+                        }
+                    }
+                } else {
+                    for (OrderDetl orderDetl : orderDetls) {
+                        for (WrkDetl wrkDetl : wrkDetls) {
+                            if (Cools.isEmpty(orderDetl.getBatch()) || Cools.isEmpty(wrkDetl.getBatch())) {
+                                if (orderDetl.getMatnr().equals(wrkDetl.getMatnr())) {
+                                    OrderDetl newOrderDetl = new OrderDetl();
+                                    newOrderDetl.sync(wrkDetl);
+                                    newOrderDetl.setQty(orderDetl.getAnfme());
+                                    newOrderDetl.setOrderId(order.getId());
+                                    newOrderDetl.setOrderNo(orderNo);
+                                    newOrderDetl.setStatus(1);
+                                    newOrderDetl.setCreateTime(order.getCreateTime());
+                                    newOrderDetl.setCreateBy(order.getCreateBy());
+                                    newOrderDetl.setUpdateTime(order.getUpdateTime());
+                                    newOrderDetl.setUpdateBy(order.getUpdateBy());
+                                    if (!orderDetlService.insert(newOrderDetl)) {
+                                        throw new CoolException("閲嶆暣鍑哄簱璁㈠崟銆恛rderNo = " + order.getOrderNo() + "銆戞槑缁嗗け璐�");
+                                    }
+                                }
+                            } else {
+                                if (orderDetl.getMatnr().equals(wrkDetl.getMatnr()) && orderDetl.getBatch().equals(wrkDetl.getBatch())) {
+                                    OrderDetl newOrderDetl = new OrderDetl();
+                                    newOrderDetl.sync(wrkDetl);
+                                    newOrderDetl.setQty(orderDetl.getAnfme());
+                                    newOrderDetl.setOrderId(order.getId());
+                                    newOrderDetl.setOrderNo(orderNo);
+                                    newOrderDetl.setStatus(1);
+                                    newOrderDetl.setCreateTime(order.getCreateTime());
+                                    newOrderDetl.setCreateBy(order.getCreateBy());
+                                    newOrderDetl.setUpdateTime(order.getUpdateTime());
+                                    newOrderDetl.setUpdateBy(order.getUpdateBy());
+                                    if (!orderDetlService.insert(newOrderDetl)) {
+                                        throw new CoolException("閲嶆暣鍑哄簱璁㈠崟銆恛rderNo = " + order.getOrderNo() + "銆戞槑缁嗗け璐�");
+                                    }
+                                }
+                            }
+                        }
                     }
                 }
             }
@@ -185,6 +225,7 @@
     public Order selectOrderMoveStatus() {
         return this.baseMapper.selectOrderMoveStatus();
     }
+
     @Override
     public Order selectOrderMoveStatusInitial() {
         return this.baseMapper.selectOrderMoveStatusInitial();

--
Gitblit v1.9.1