From e6d90f4aefc88f6317578bd9c0c17c768ccb96e4 Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期五, 16 一月 2026 10:07:20 +0800
Subject: [PATCH] 生产订单增加查看bom结构

---
 src/main/java/com/ruoyi/sales/service/impl/SalesLedgerProductServiceImpl.java |    2 +-
 src/main/java/com/ruoyi/production/mapper/ProductOrderMapper.java             |    4 ++++
 src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java  |    7 +++++++
 src/main/resources/mapper/production/ProductOrderMapper.xml                   |   23 +++++++++++++++++++++++
 src/main/java/com/ruoyi/production/controller/ProductOrderController.java     |    7 +++++++
 src/main/java/com/ruoyi/production/dto/ProductOrderDto.java                   |    8 ++++++++
 src/main/java/com/ruoyi/production/service/ProductOrderService.java           |    3 +++
 src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java        |    4 +---
 8 files changed, 54 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/controller/ProductOrderController.java b/src/main/java/com/ruoyi/production/controller/ProductOrderController.java
index 978e9b3..658b40a 100644
--- a/src/main/java/com/ruoyi/production/controller/ProductOrderController.java
+++ b/src/main/java/com/ruoyi/production/controller/ProductOrderController.java
@@ -57,4 +57,11 @@
         util.exportExcel(response, list, "鐢熶骇璁㈠崟鏁版嵁");
     }
 
+    @ApiOperation("鏌ヨ鐢熶骇璁㈠崟瀵瑰簲鐨凚OM")
+    @GetMapping("/listProcessBom")
+    public R listProcessBom(Long orderId) {
+        return R.ok(productOrderService.listProcessBom(orderId));
+    }
+
+
 }
diff --git a/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java b/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java
index 3827dd7..b12803d 100644
--- a/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java
+++ b/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java
@@ -35,4 +35,12 @@
     @ApiModelProperty(value = "宸ヨ壓璺嚎缂栧彿")
     @Excel(name = "宸ヨ壓璺嚎缂栧彿")
     private String processRouteCode;
+
+    @ApiModelProperty(value = "瀹屾垚鐘舵��")
+    @Excel(name = "瀹屾垚鐘舵��")
+    private BigDecimal completionStatus;
+
+    @ApiModelProperty(value = "BOM缂栧彿")
+    @Excel(name = "BOM缂栧彿")
+    private String bomNo;
 }
diff --git a/src/main/java/com/ruoyi/production/mapper/ProductOrderMapper.java b/src/main/java/com/ruoyi/production/mapper/ProductOrderMapper.java
index 7e668b6..94d41f3 100644
--- a/src/main/java/com/ruoyi/production/mapper/ProductOrderMapper.java
+++ b/src/main/java/com/ruoyi/production/mapper/ProductOrderMapper.java
@@ -3,7 +3,9 @@
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.production.dto.ProductBomDto;
 import com.ruoyi.production.dto.ProductOrderDto;
+import com.ruoyi.production.dto.ProductStructureDto;
 import com.ruoyi.production.pojo.ProcessRoute;
 import com.ruoyi.production.pojo.ProductOrder;
 import org.apache.ibatis.annotations.Mapper;
@@ -21,4 +23,6 @@
      ProductOrderDto productMainByOrderId(@Param("c") ProductOrder productOrder);
 
     List<ProcessRoute> listProcessRoute(@Param("productModelId") Long productModelId);
+
+    List<ProductStructureDto> listProcessBom(@Param("orderId") Long orderId);
 }
diff --git a/src/main/java/com/ruoyi/production/service/ProductOrderService.java b/src/main/java/com/ruoyi/production/service/ProductOrderService.java
index 9dd61fb..78a3de1 100644
--- a/src/main/java/com/ruoyi/production/service/ProductOrderService.java
+++ b/src/main/java/com/ruoyi/production/service/ProductOrderService.java
@@ -3,7 +3,9 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.IService;
+import com.ruoyi.production.dto.ProductBomDto;
 import com.ruoyi.production.dto.ProductOrderDto;
+import com.ruoyi.production.dto.ProductStructureDto;
 import com.ruoyi.production.pojo.ProcessRoute;
 import com.ruoyi.production.pojo.ProductOrder;
 
@@ -18,4 +20,5 @@
 
     List<ProcessRoute> listProcessRoute(Long productModelId);
 
+    List<ProductStructureDto> listProcessBom(Long orderId);
 }
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 14426c4..075815c 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductOrderServiceImpl.java
@@ -4,7 +4,9 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.production.dto.ProductBomDto;
 import com.ruoyi.production.dto.ProductOrderDto;
+import com.ruoyi.production.dto.ProductStructureDto;
 import com.ruoyi.production.mapper.*;
 import com.ruoyi.production.pojo.*;
 import com.ruoyi.production.service.ProcessRouteService;
@@ -101,4 +103,9 @@
     public List<ProcessRoute> listProcessRoute(Long productModelId) {
         return productOrderMapper.listProcessRoute(productModelId);
     }
+
+    @Override
+    public List<ProductStructureDto> listProcessBom(Long orderId) {
+        return productOrderMapper.listProcessBom(orderId);
+    }
 }
diff --git a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerProductServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerProductServiceImpl.java
index fa9eb9a..4816bfb 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerProductServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerProductServiceImpl.java
@@ -245,7 +245,7 @@
                         ProductWorkOrder productWorkOrder = new ProductWorkOrder();
                         productWorkOrder.setProductProcessRouteItemId(productProcessRouteItem.getId());
                         productWorkOrder.setProductOrderId(productOrder.getId());
-                        productWorkOrder.setQuantity(salesLedgerProduct.getQuantity());
+                        productWorkOrder.setPlanQuantity(salesLedgerProduct.getQuantity());
                         productWorkOrder.setPlanQuantity(salesLedgerProduct.getQuantity());
                         productWorkOrder.setWorkOrderNo(workOrderNoStr);
                         productWorkOrder.setStatus(1);
diff --git a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
index 90e4b07..ae57130 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
@@ -750,12 +750,10 @@
                             ProductWorkOrder productWorkOrder = new ProductWorkOrder();
                             productStructureDtos.stream().forEach(productStructureDto -> {
                                 if (productStructureDto.getProductModelId().equals(productProcessRouteItem.getProductModelId())){
-                                    productWorkOrder.setQuantity(productStructureDto.getUnitQuantity().multiply(salesLedgerProduct.getQuantity()));
-                                    productWorkOrder.setPlanQuantity(productWorkOrder.getQuantity());
+                                    productWorkOrder.setPlanQuantity(productStructureDto.getUnitQuantity().multiply(salesLedgerProduct.getQuantity()));
                                 }
                             });
                             if (Objects.equals(productProcessRouteItem.getProductModelId(), salesLedgerProduct.getProductModelId())) {
-                                productWorkOrder.setQuantity(salesLedgerProduct.getQuantity());
                                 productWorkOrder.setPlanQuantity(salesLedgerProduct.getQuantity());
                             }
                             productWorkOrder.setProductProcessRouteItemId(productProcessRouteItem.getId());
diff --git a/src/main/resources/mapper/production/ProductOrderMapper.xml b/src/main/resources/mapper/production/ProductOrderMapper.xml
index 7fe84fa..b47d5cf 100644
--- a/src/main/resources/mapper/production/ProductOrderMapper.xml
+++ b/src/main/resources/mapper/production/ProductOrderMapper.xml
@@ -20,11 +20,13 @@
         slp.product_category,
         slp.specification_model,
         ppr.process_route_code,
+        pb.bom_no,
         ROUND(po.complete_quantity / po.quantity * 100, 2) AS completionStatus
         from product_order po
         left join sales_ledger sl on po.sales_ledger_id = sl.id
         left join sales_ledger_product slp on po.product_model_id = slp.id
         left join product_process_route ppr on po.id = ppr.product_order_id
+        left join product_bom pb on pb.id = ppr.bom_id
         <where>
             <if test="c.npsNo != null and c.npsNo != ''">
                 and po.nps_no like concat('%',#{c.npsNo},'%')
@@ -61,6 +63,27 @@
                  left join sales_ledger_product slp on pm.id = slp.product_model_id
         where slp.id = #{productModelId}
     </select>
+    <select id="listProcessBom" resultType="com.ruoyi.production.dto.ProductStructureDto">
+        select ps.id,
+               ps.product_model_id,
+               ps.process_id,
+               ps.unit_quantity,
+               ps.unit_quantity * po.quantity as demandedQuantity,
+               ps.unit,
+               p.product_name,
+               pp.name as  process_name,
+               pm.product_id,
+               pm.model
+        from
+            product_structure ps
+                left join product_model pm on ps.product_model_id = pm.id
+                left join product p on pm.product_id = p.id
+                left join product_process pp on ps.process_id = pp.id
+                left join product_process_route ppr on ps.bom_id = ppr.bom_id
+                left join product_order po on po.id = ppr.product_order_id
+        where ppr.product_order_id = #{orderId}
+        order by ps.id
+    </select>
 
 
 </mapper>

--
Gitblit v1.9.3