From 8b116fd4f2633194b050a0eca13964ce4f2e18f7 Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期五, 01 八月 2025 16:41:22 +0800
Subject: [PATCH] 订单转生产订单根据工艺流程区分不同产品,报工修改逻辑调整

---
 north-glass-erp/src/main/resources/mapper/pp/WordOrder.xml |   40 +++++++++++++++++++++++++++++++++-------
 1 files changed, 33 insertions(+), 7 deletions(-)

diff --git a/north-glass-erp/src/main/resources/mapper/pp/WordOrder.xml b/north-glass-erp/src/main/resources/mapper/pp/WordOrder.xml
index cb6e497..03a7286 100644
--- a/north-glass-erp/src/main/resources/mapper/pp/WordOrder.xml
+++ b/north-glass-erp/src/main/resources/mapper/pp/WordOrder.xml
@@ -17,6 +17,7 @@
             <result column="area" property="order.area"/>
             <result column="creator" property="order.creator"/>
         <result column="customer_name" property="order.customerName"/>
+        <result column="processing_note" property="order.processingNote"/>
 <!--        <association property="orderDetail" javaType="com.example.erp.entity.sd.OrderDetail">-->
 <!--            <result column="product_id" property="productId"/>-->
 <!--            <result column="product_name" property="productName"/>-->
@@ -27,8 +28,19 @@
 <!--            <result column="bend_radius" property="bendRadius"/>-->
 <!--            <result column="processing_note" property="processingNote"/>-->
             <result column="gross_area" property="orderDetail.grossArea"/>
+
 <!--        </association>-->
 
+    </resultMap>
+
+    <resultMap id="addWordOrderMap" type="com.example.erp.entity.sd.OrderDetail">
+        <result column="order_id" property="orderId"/>
+        <result column="product_id" property="productId"/>
+        <result column="product_name" property="productName"/>
+        <result column="compute_gross_area" property="computeGrossArea"/>
+        <result column="quantity" property="quantity"/>
+        <result column="perimeter" property="perimeter"/>
+        <result column="process" property="orderGlassDetail.process"/>
     </resultMap>
 
     <select id="selectWordOrder" resultMap="wordOrderMap">
@@ -40,11 +52,12 @@
         o.area as gross_area,
         o.quantity as quantity,
         o.creator,
-        o.customer_name
+        o.customer_name,
+        o.processing_note
         from sd.order_detail  as od
         left join `order` as o
         on o.order_id=od.order_id
-        where o.production_order!=2 and o.order_review=2
+        where o.production_order!=2 and o.order_review=2 and o.create_order>0
 
         <if test="orderGlassDetail.orderId != null and orderGlassDetail.orderId != ''">
             and o.order_id regexp #{orderGlassDetail.orderId}
@@ -61,6 +74,9 @@
         </if>
         <if test="orderGlassDetail.order.customerName != null and orderGlassDetail.order.customerName!= ''">
             and o.customer_name regexp #{orderGlassDetail.order.customerName}
+        </if>
+        <if test="orderGlassDetail.order.processingNote != null and orderGlassDetail.order.processingNote!= ''">
+            and o.processing_note regexp #{orderGlassDetail.order.processingNote}
         </if>
 
         <if test="orderGlassDetail.createTime != ''">
@@ -87,7 +103,8 @@
         (od.quantity) as quantity,
         o.creator,
         od.id,
-        o.customer_name
+        o.customer_name,
+        o.processing_note
         from sd.order_glass_detail  as ogd
         left join  order_detail as od
         on od.order_id=ogd.order_id
@@ -114,6 +131,9 @@
         <if test="orderGlassDetail.order.customerName != null and orderGlassDetail.order.customerName!= ''">
             and o.customer_name regexp #{orderGlassDetail.order.customerName}
         </if>
+        <if test="orderGlassDetail.order.processingNote != null and orderGlassDetail.order.processingNote!= ''">
+            and o.processing_note regexp #{orderGlassDetail.order.processingNote}
+        </if>
 
         <if test="orderGlassDetail.createTime != ''">
             and DATE_FORMAT((o.create_time),'%Y-%m-%d') BETWEEN #{ selectTime1 } AND #{ selectTime2 }
@@ -122,17 +142,22 @@
         order by od.id desc
     </select>
 
-    <select id="addWordOrder">
+    <select id="addWordOrder" resultMap="addWordOrderMap">
         select od.order_id,
         od.product_id,
         od.product_name,
         sum( od.quantity) as quantity,
         od.compute_gross_area,
-        od.perimeter
+        od.perimeter,
+        ogd.process
         from sd.order_detail as od
         left join sd.order as o
         on od.order_id =o.order_id
-        where od.order_id = #{orderId} and o.production_order!=2
+        left join (
+        select order_id,order_number,process from
+               sd.order_glass_detail where FIND_IN_SET(order_id,#{orderId}) GROUP BY order_id,order_number
+        ) as ogd on ogd.order_id = o.order_id and ogd.order_number=od.order_number
+        where FIND_IN_SET(od.order_id,#{orderId})    and o.production_order!=2
         <if test="orderDetail.orderId != null and orderDetail.orderId != ''">
             and od.order_id regexp #{orderDetail.orderId}
         </if>
@@ -142,7 +167,7 @@
         <if test="orderDetail.productName != null and orderDetail.productName != ''">
             and od.product_name regexp #{orderDetail.productName}
         </if>
-        group by od.order_id, od.product_id, od.product_name
+        group by od.order_id, od.product_id, od.product_name,ogd.process
         ;
     </select>
 
@@ -163,6 +188,7 @@
         where od.order_id = #{orderId}
           and od.product_id = #{productId}
           and od.product_name = #{productName}
+          and ogd.process = #{process}
     </update>
 
     <!--    鍒犻櫎宸ュ崟-->

--
Gitblit v1.8.0