From a85bc05fb3a7dc9c67930a1b412cf5b1be172fd5 Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期四, 19 十二月 2024 16:44:06 +0800
Subject: [PATCH] 修改报工新增为通过判断工序是否为复合工序报工

---
 north-glass-erp/src/main/resources/mapper/pp/Report.xml |   60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 56 insertions(+), 4 deletions(-)

diff --git a/north-glass-erp/src/main/resources/mapper/pp/Report.xml b/north-glass-erp/src/main/resources/mapper/pp/Report.xml
index 0398c11..4aebb63 100644
--- a/north-glass-erp/src/main/resources/mapper/pp/Report.xml
+++ b/north-glass-erp/src/main/resources/mapper/pp/Report.xml
@@ -152,6 +152,7 @@
         <result column="product_name" property="productName"/>
         <result column="bend_radius" property="bendRadius"/>
         <result column="glassNumber" property="glassNumber"/>
+        <result column="teams_groups_name" property="teamsGroupsName"/>
     </resultMap>
 
     <!--    娴佺▼鍗¤繘搴�-->
@@ -338,7 +339,8 @@
         odpd.broken_num) / 1000000, 2) as stockArea,
         od.product_name,
         od.bend_radius,
-        ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') AS glassNumber
+        ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') AS glassNumber,
+        rws.teams_groups_name
 
         from sd.order_detail AS od
         LEFT JOIN sd.order_glass_detail AS ogd
@@ -374,6 +376,14 @@
         and c.technology_number = fc.technology_number
         left join sd.`order` as o
         on o.order_id = od.order_id
+        left join
+        (
+        select a.process_id,a.teams_groups_name,a.next_process,b.technology_number,b.order_number
+        from reporting_work  as a
+        left join reporting_work_detail as b on a.reporting_work_id=b.reporting_work_id
+        GROUP BY a.process_id,a.teams_groups_name,a.next_process,b.order_number,b.technology_number
+        ) as rws on rws.process_id=fc.process_id and rws.order_number=fc.order_number
+                        and  rws.technology_number=fc.technology_number and rws.next_process=#{selectProcesses}
         where LENGTH(fc.process_id) = 14
         and odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num != 0
@@ -447,6 +457,14 @@
         and c.technology_number = fc.technology_number
         left join sd.`order` as o
         on o.order_id = od.order_id
+        left join
+        (
+        select a.process_id,a.teams_groups_name,a.next_process,b.technology_number,b.order_number
+        from reporting_work  as a
+        left join reporting_work_detail as b on a.reporting_work_id=b.reporting_work_id
+        GROUP BY a.process_id,a.teams_groups_name,a.next_process,b.order_number,b.technology_number
+        ) as rws on rws.process_id=fc.process_id and rws.order_number=fc.order_number
+        and  rws.technology_number=fc.technology_number and rws.next_process=#{selectProcesses}
         where LENGTH(fc.process_id) = 14
         and odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num != 0
@@ -741,7 +759,7 @@
 
     <select id="productionScheduleMp">
         select a.order_number,
-               if(od.shape='' || ISNULL(od.shape),'鏅舰',if(od.shape = 1, '鏅舰', if(od.shape = 2, '寮傚舰', ''))) as shape,
+               if(a.shape='' || ISNULL(a.shape),'鏅舰',if(a.shape = 1, '鏅舰', if(a.shape = 2, '寮傚舰', ''))) as shape,
                a.product_name,
                b.child_width,
                b.child_height,
@@ -1430,7 +1448,8 @@
         sum(ROUND(ogd.child_width * ogd.child_height *
         (odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num) / 1000000, 2)) as stockArea,
-        od.product_name
+        od.product_name,
+        rws.teams_groups_name
 
         from sd.order_detail AS od
         LEFT JOIN sd.order_glass_detail AS ogd
@@ -1466,6 +1485,14 @@
         and c.technology_number = fc.technology_number
         left join sd.`order` as o
         on o.order_id = od.order_id
+        left join
+        (
+        select a.process_id,a.teams_groups_name,a.next_process,b.technology_number,b.order_number
+        from reporting_work  as a
+        left join reporting_work_detail as b on a.reporting_work_id=b.reporting_work_id
+        GROUP BY a.process_id,a.teams_groups_name,a.next_process,b.order_number,b.technology_number
+        ) as rws on rws.process_id=fc.process_id and rws.order_number=fc.order_number
+        and  rws.technology_number=fc.technology_number and rws.next_process=#{selectProcesses}
         where LENGTH(fc.process_id) = 14
         and odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num != 0
@@ -1527,6 +1554,14 @@
         and c.technology_number = fc.technology_number
         left join sd.`order` as o
         on o.order_id = od.order_id
+        left join
+        (
+        select a.process_id,a.teams_groups_name,a.next_process,b.technology_number,b.order_number
+        from reporting_work  as a
+        left join reporting_work_detail as b on a.reporting_work_id=b.reporting_work_id
+        GROUP BY a.process_id,a.teams_groups_name,a.next_process,b.order_number,b.technology_number
+        ) as rws on rws.process_id=fc.process_id and rws.order_number=fc.order_number
+        and  rws.technology_number=fc.technology_number and rws.next_process=#{selectProcesses}
         where LENGTH(fc.process_id) = 14
         and odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num != 0
@@ -1562,7 +1597,8 @@
         sum(ROUND(ogd.child_width * ogd.child_height *
         (odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num) / 1000000, 2)) as stockArea,
-        od.product_name
+        od.product_name,
+        rws.teams_groups_name
 
         from sd.order_detail AS od
         LEFT JOIN sd.order_glass_detail AS ogd
@@ -1598,6 +1634,14 @@
         and c.technology_number = fc.technology_number
         left join sd.`order` as o
         on o.order_id = od.order_id
+        left join
+        (
+        select a.process_id,a.teams_groups_name,a.next_process,b.technology_number,b.order_number
+        from reporting_work  as a
+        left join reporting_work_detail as b on a.reporting_work_id=b.reporting_work_id
+        GROUP BY a.process_id,a.teams_groups_name,a.next_process,b.order_number,b.technology_number
+        ) as rws on rws.process_id=fc.process_id and rws.order_number=fc.order_number
+        and  rws.technology_number=fc.technology_number and rws.next_process=#{selectProcesses}
         where LENGTH(fc.process_id) = 14
         and odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num != 0
@@ -1662,6 +1706,14 @@
         and c.technology_number = fc.technology_number
         left join sd.`order` as o
         on o.order_id = od.order_id
+        left join
+        (
+        select a.process_id,a.teams_groups_name,a.next_process,b.technology_number,b.order_number
+        from reporting_work  as a
+        left join reporting_work_detail as b on a.reporting_work_id=b.reporting_work_id
+        GROUP BY a.process_id,a.teams_groups_name,a.next_process,b.order_number,b.technology_number
+        ) as rws on rws.process_id=fc.process_id and rws.order_number=fc.order_number
+        and  rws.technology_number=fc.technology_number and rws.next_process=#{selectProcesses}
         where LENGTH(fc.process_id) = 14
         and odpds.reporting_work_num_count + ifnull(c.patchNumSum, 0) - odpd.reporting_work_num_count -
         odpd.broken_num != 0

--
Gitblit v1.8.0