From 79838fcce660796b2571e6fc3f8731b2719115c4 Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期四, 05 三月 2026 13:30:26 +0800
Subject: [PATCH] 生产订单:新增时判断工艺路线项目是否存在

---
 src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java |   68 ++++++++++++++++++----------------
 1 files changed, 36 insertions(+), 32 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java
index 53d3a32..1b04cd0 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java
@@ -19,6 +19,7 @@
 import com.ruoyi.quality.pojo.QualityInspect;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.util.CollectionUtils;
 
 import java.math.BigDecimal;
 import java.time.LocalDate;
@@ -85,42 +86,45 @@
         List<ProcessRouteItem> processRouteItems = processRouteItemMapper.selectList(new QueryWrapper<ProcessRouteItem>().lambda().eq(ProcessRouteItem::getRouteId, processRoute.getId()).orderByDesc(ProcessRouteItem::getDragSort));
         // 鐢熸垚褰撳墠鏃ユ湡鐨勫墠缂�锛氬勾鏈堟棩
         String datePrefix = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyyMMdd"));
-        ProcessRouteItem processRouteItem = processRouteItems.get(0);
-//        for (ProcessRouteItem processRouteItem : processRouteItems) {
-        ProductProcessRouteItem productProcessRouteItem = new ProductProcessRouteItem();
-        productProcessRouteItem.setProductModelId(processRouteItem.getProductModelId());
-        productProcessRouteItem.setProcessId(processRouteItem.getProcessId());
-        productProcessRouteItem.setProductOrderId(productOrder.getId());
-        productProcessRouteItem.setProductRouteId(productProcessRoute.getId());
-        productProcessRouteItem.setDragSort(processRouteItem.getDragSort());
-        int insert = productProcessRouteItemMapper.insert(productProcessRouteItem);
-        if (insert > 0) {
-            // 鏌ヨ浠婃棩宸插瓨鍦ㄧ殑鏈�澶у伐鍗曞彿
-            ProductWorkOrder lastWorkOrder = productWorkOrderMapper.selectMax(datePrefix);
-            int sequenceNumber = 1; // 榛樿搴忓彿
-            if (lastWorkOrder != null && lastWorkOrder.getWorkOrderNo() != null) {
-                String lastNo = lastWorkOrder.getWorkOrderNo().toString();
-                if (lastNo.startsWith(datePrefix)) {
-                    String seqStr = lastNo.substring(datePrefix.length());
-                    try {
-                        sequenceNumber = Integer.parseInt(seqStr) + 1;
-                    } catch (NumberFormatException e) {
-                        sequenceNumber = 1;
+        if (!CollectionUtils.isEmpty(processRouteItems)) {
+            ProcessRouteItem processRouteItem = processRouteItems.get(0);
+            //        for (ProcessRouteItem processRouteItem : processRouteItems) {
+            ProductProcessRouteItem productProcessRouteItem = new ProductProcessRouteItem();
+            productProcessRouteItem.setProductModelId(processRouteItem.getProductModelId());
+            productProcessRouteItem.setProcessId(processRouteItem.getProcessId());
+            productProcessRouteItem.setProductOrderId(productOrder.getId());
+            productProcessRouteItem.setProductRouteId(productProcessRoute.getId());
+            productProcessRouteItem.setDragSort(processRouteItem.getDragSort());
+            int insert = productProcessRouteItemMapper.insert(productProcessRouteItem);
+            if (insert > 0) {
+                // 鏌ヨ浠婃棩宸插瓨鍦ㄧ殑鏈�澶у伐鍗曞彿
+                ProductWorkOrder lastWorkOrder = productWorkOrderMapper.selectMax(datePrefix);
+                int sequenceNumber = 1; // 榛樿搴忓彿
+                if (lastWorkOrder != null && lastWorkOrder.getWorkOrderNo() != null) {
+                    String lastNo = lastWorkOrder.getWorkOrderNo().toString();
+                    if (lastNo.startsWith(datePrefix)) {
+                        String seqStr = lastNo.substring(datePrefix.length());
+                        try {
+                            sequenceNumber = Integer.parseInt(seqStr) + 1;
+                        } catch (NumberFormatException e) {
+                            sequenceNumber = 1;
+                        }
                     }
                 }
-            }
-            // 鐢熸垚瀹屾暣鐨勫伐鍗曞彿
-            String workOrderNoStr = "GD" + String.format("%s%03d", datePrefix, sequenceNumber);
-            ProductWorkOrder productWorkOrder = new ProductWorkOrder();
-            productWorkOrder.setProductProcessRouteItemId(productProcessRouteItem.getId());
-            productWorkOrder.setProductOrderId(productOrder.getId());
-            ProductOrder order = productOrderMapper.selectById(productOrder.getId());
-            productWorkOrder.setPlanQuantity(order.getQuantity());
-            productWorkOrder.setWorkOrderNo(workOrderNoStr);
-            productWorkOrder.setStatus(1);
-            productWorkOrderMapper.insert(productWorkOrder);
+                // 鐢熸垚瀹屾暣鐨勫伐鍗曞彿
+                String workOrderNoStr = "GD" + String.format("%s%03d", datePrefix, sequenceNumber);
+                ProductWorkOrder productWorkOrder = new ProductWorkOrder();
+                productWorkOrder.setProductProcessRouteItemId(productProcessRouteItem.getId());
+                productWorkOrder.setProductOrderId(productOrder.getId());
+                ProductOrder order = productOrderMapper.selectById(productOrder.getId());
+                productWorkOrder.setPlanQuantity(order.getQuantity());
+                productWorkOrder.setWorkOrderNo(workOrderNoStr);
+                productWorkOrder.setStatus(1);
+                productWorkOrderMapper.insert(productWorkOrder);
 //            }
+            }
         }
+
         return productOrderMapper.updateById(productOrder);
     }
 

--
Gitblit v1.9.3