From b584d2d89076149ad0e60cb67a3efcacda33b5e1 Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期二, 24 三月 2026 14:05:59 +0800
Subject: [PATCH] 实际合格率低于【合格率】时,每个【生产工单】、【生产报工】台账需要标红显示。并发送消息到管理员,内容为:【xxx生产订单,xx工序合格率xx%低于标准xx%】

---
 src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java |   22 +++++++++++++++++++++-
 1 files changed, 21 insertions(+), 1 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java
index 8c38ddf..b979cc4 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java
@@ -73,6 +73,25 @@
                     record.setIsCanReport(true);
                 }
             }
+
+            // 鏌ヨ褰撳墠瀹為檯鐨勫悎鏍肩巼
+            // 鏌ヨ鍏宠仈浜у嚭琛ㄦ暟鎹�
+            List<ProductionProductMain> productionProductMains = productionProductMainMapper.selectList(Wrappers.<ProductionProductMain>lambdaQuery().eq(ProductionProductMain::getWorkOrderId, record.getId()));
+            BigDecimal totalScrapQty = BigDecimal.ZERO;
+            if (CollectionUtils.isNotEmpty(productionProductMains)) {
+                // 璁$畻鎶ュ簾鏁伴噺
+                List<Long> mainIds = productionProductMains.stream().map(ProductionProductMain::getId).collect(Collectors.toList());
+                List<ProductionProductOutput> productionProductOutputs = productionProductOutputMapper.selectList(Wrappers.<ProductionProductOutput>lambdaQuery().in(ProductionProductOutput::getProductMainId, mainIds));
+                totalScrapQty = productionProductOutputs.stream().map(ProductionProductOutput::getScrapQty).reduce(BigDecimal.ZERO, BigDecimal::add);
+            }
+            if (record.getCompleteQuantity().compareTo(BigDecimal.ZERO) > 0) {
+                record.setActualQualifiedRate((record.getCompleteQuantity().subtract(totalScrapQty))
+                        .divide(record.getCompleteQuantity(), 2, RoundingMode.HALF_UP)
+                        .multiply(new BigDecimal("100"))
+                );
+            } else {
+                record.setActualQualifiedRate((record.getCompleteQuantity().subtract(totalScrapQty)).multiply(BigDecimal.valueOf(100)));
+            }
         });
         return productWorkOrderDtoIPage;
     }
@@ -154,10 +173,11 @@
                     scrapQty = productionProductOutputs.stream().map(ProductionProductOutput::getScrapQty).reduce(BigDecimal.ZERO, BigDecimal::add);
                 }
                 if (productWorkOrderDto.getCompleteQuantity().compareTo(BigDecimal.ZERO) > 0) {
-                    productWorkOrderDto.setScrapRate(scrapQty.divide(productWorkOrderDto.getCompleteQuantity(), 2, RoundingMode.HALF_UP));
+                    productWorkOrderDto.setScrapRate(scrapQty.divide(productWorkOrderDto.getCompleteQuantity(), 4, RoundingMode.HALF_UP));
                 } else {
                     productWorkOrderDto.setScrapRate(scrapQty.multiply(BigDecimal.valueOf(100)));
                 }
+                productWorkOrderDto.setScrapQty(scrapQty);
                 productWorkOrderDto.setCompleteQty(productWorkOrderDto.getCompleteQuantity().subtract(scrapQty));
             });
         }

--
Gitblit v1.9.3