From fec9f42e00f2df68a2a20cbf132b17bdeed8e63a Mon Sep 17 00:00:00 2001
From: 廖井涛 <2265517004@qq.com>
Date: 星期一, 25 八月 2025 09:19:52 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 north-glass-erp/src/main/resources/mapper/pp/Report.xml |  243 +++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 195 insertions(+), 48 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 49f9fad..4892304 100644
--- a/north-glass-erp/src/main/resources/mapper/pp/Report.xml
+++ b/north-glass-erp/src/main/resources/mapper/pp/Report.xml
@@ -186,17 +186,17 @@
                c.quantity-ifnull(c.termination_quantity,0) as glassQuantity,
 
                c.quantity-ifnull(c.termination_quantity,0) as quantityShow,
-               (c.quantity-ifnull(c.termination_quantity,0))*a.compute_area as grossAreaShow,
-               ifnull(f.inventory, 0) as inventoryShow,
-               round(ifnull(f.inventory, 0) * a.compute_area, 2) as inventoryAreaShow, -- 搴撳瓨闈㈢Н
+               round( (c.quantity-ifnull(c.termination_quantity,0))*a.compute_area,2) as grossAreaShow,
+               ifnull(c.received_quantity, 0) as StorageShow,
                ifnull(dd.quantity, 0) as shippedQuantityShow, -- 鍙戣揣鏁伴噺
-               (ifnull(c.received_quantity, 0))*a.compute_area  as StorageAreaShow,-- 鍏ュ簱闈㈢Н
+               round(ifnull(dd.quantity, 0)*a.compute_area,2) as shippedAreaShow, -- 鍙戣揣闈㈢Н
+               round((ifnull(c.received_quantity, 0))*a.compute_area,2)  as StorageAreaShow,-- 鍏ュ簱闈㈢Н
 
-               if(c.technology_number=1,(c.quantity-ifnull(c.termination_quantity,0))*a.compute_area,0) as grossArea,
-               if(c.technology_number=1,ifnull(f.inventory, 0) ,0)                        as inventory,
-               if(c.technology_number=1,round(ifnull(f.inventory, 0) * a.compute_area, 2),0)      as inventoryArea,
+               if(c.technology_number=1, round((c.quantity-ifnull(c.termination_quantity,0))*a.compute_area,2),0) as grossArea,
+               if(c.technology_number=1,ifnull(c.received_quantity, 0) ,0)                        as Storage,
                if(c.technology_number=1,ifnull(dd.quantity, 0) ,0)                          as shippedQuantity,
-               if(c.technology_number=1,(ifnull(c.received_quantity, 0))*a.compute_area,0)  as StorageArea,
+               if(c.technology_number=1,round(ifnull(dd.quantity, 0)*a.compute_area,2),0)         as shippedArea,
+               if(c.technology_number=1, round((ifnull(c.received_quantity, 0))*a.compute_area,2),0)  as StorageArea,
 
 
                ifnull(JSON_UNQUOTE(JSON_EXTRACT(a.other_columns, '$.S01')),'') AS glassNumber,
@@ -213,8 +213,8 @@
                                and c.technology_number = b.technology_number
                  left join sd.`order` as d
                            on c.order_id = d.order_id
-                 left join mm.finished_goods_inventory as f
-                           on c.order_id = f.order_id and f.order_number = c.order_number
+#                  left join mm.finished_goods_inventory as f
+#                            on c.order_id = f.order_id and f.order_number = c.order_number
                  left join sd.delivery_detail as dd on dd.order_id = a.order_id and dd.order_number = a.order_number
                  left join (SELECT process_id,
                                    order_number,
@@ -1367,56 +1367,74 @@
 
     <select id="teamOutputMp" resultMap="teamOutputMap">
         SELECT
+        *
+        FROM
+        (
+        SELECT
         rw.reporting_work_time,
         rw.this_process,
         rw.teams_groups_name,
         o.project,
         rw.process_id,
         fc.order_number,
-        MAX( ogd.child_width ) as width,
-        MAX( ogd.child_height ) as height,
+        MAX(ogd.child_width)  AS width,
+        MAX(ogd.child_height) AS height,
         od.edging_type,
-        rwd.completed_quantity as completed_quantity,
-        ROUND(MAX( ogd.child_width )*MAX( ogd.child_height )*rwd.completed_quantity/1000000,2) as area,
+        rwd.completed_quantity AS completed_quantity,
+        ROUND(MAX(ogd.child_width) * MAX(ogd.child_height) * rwd.completed_quantity / 1000000, 2) AS area,
         od.product_name,
-        JSON_UNQUOTE( JSON_EXTRACT( od.other_columns, '$.S01' )) AS code,
+        JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')) AS code,
         rw.reviewed,
         rw.examine_time,
         rw.device_name,
         o.order_type,
---         GROUP_CONCAT(ogd.glass_child SEPARATOR '+') as workProcessName
         CASE
-        WHEN LOCATE('step',#{laminating})>0 THEN GROUP_CONCAT(ogd.glass_child SEPARATOR '+')
-        ELSE MAX( ogd.glass_child )
+        WHEN LOCATE('step', #{laminating}) > 0 THEN GROUP_CONCAT(ogd.glass_child SEPARATOR '+')
+        ELSE MAX(ogd.glass_child)
         END AS workProcessName,
-            o.batch
+        o.batch
         FROM
-        reporting_work as rw left join reporting_work_detail as rwd on rwd.reporting_work_id=rw.reporting_work_id
-        left join flow_card as fc on fc.order_id=rw.order_id and fc.process_id=rw.process_id  and fc.order_number=rwd.order_number and fc.technology_number=rwd.technology_number
-        left join sd.order_glass_detail as ogd on ogd.order_id=fc.order_id and ogd.order_number=fc.order_number and ogd.technology_number=fc.technology_number
-        left join sd.order_detail as od  on od.order_id=ogd.order_id and od.order_number=ogd.order_number
-        left join sd.`order` as o on o.order_id=od.order_id
-        where o.create_order>0 and rw.reviewed_state>=0 and rwd.completed_quantity>0 and
-        rw.reporting_work_time >= #{selectTime1}
+        reporting_work AS rw
+        LEFT JOIN reporting_work_detail AS rwd
+        ON rwd.reporting_work_id = rw.reporting_work_id
+        LEFT JOIN flow_card AS fc
+        ON fc.order_id = rw.order_id
+        AND fc.process_id = rw.process_id
+        AND fc.order_number = rwd.order_number
+        AND fc.technology_number = rwd.technology_number
+        LEFT JOIN sd.order_glass_detail AS ogd
+        ON ogd.order_id = fc.order_id
+        AND ogd.order_number = fc.order_number
+        AND ogd.technology_number = fc.technology_number
+        LEFT JOIN sd.order_detail AS od
+        ON od.order_id = ogd.order_id
+        AND od.order_number = ogd.order_number
+        LEFT JOIN sd.`order` AS o
+        ON o.order_id = od.order_id
+        WHERE
+        o.create_order > 0
+        AND rw.reviewed_state >= 0
+        AND rwd.completed_quantity > 0
+        AND rw.reporting_work_time &gt;= #{selectTime1}
         AND rw.reporting_work_time &lt;  #{selectTime2}
-        and position(#{selectProcesses} in rw.this_process)
+        AND POSITION(#{selectProcesses} IN rw.this_process)
         <if test="teamOutputDTO.thisProcess != null and teamOutputDTO.thisProcess != ''">
-            and rw.this_process regexp #{teamOutputDTO.thisProcess}
+            AND rw.this_process REGEXP #{teamOutputDTO.thisProcess}
         </if>
         <if test="teamOutputDTO.teamsGroupsName != null and teamOutputDTO.teamsGroupsName != ''">
-            and rw.teams_groups_name regexp #{teamOutputDTO.teamsGroupsName}
+            AND rw.teams_groups_name REGEXP #{teamOutputDTO.teamsGroupsName}
         </if>
         <if test="teamOutputDTO.project != null and teamOutputDTO.project != ''">
-            and o.project regexp #{teamOutputDTO.project}
+            AND o.project REGEXP #{teamOutputDTO.project}
         </if>
         <if test="teamOutputDTO.processId != null and teamOutputDTO.processId != ''">
-            and rw.process_id regexp #{teamOutputDTO.processId}
+            AND rw.process_id REGEXP #{teamOutputDTO.processId}
         </if>
         <if test="teamOutputDTO.edgingType != null and teamOutputDTO.edgingType != ''">
-            and od.edging_type regexp #{teamOutputDTO.edgingType}
+            AND od.edging_type REGEXP #{teamOutputDTO.edgingType}
         </if>
         <if test="teamOutputDTO.deviceName != null and teamOutputDTO.deviceName != ''">
-            and rw.device_name regexp #{teamOutputDTO.deviceName}
+            AND rw.device_name REGEXP #{teamOutputDTO.deviceName}
         </if>
 
         <choose>
@@ -1431,7 +1449,7 @@
             </when>
             <otherwise>
                 GROUP BY
-                <if test="laminating == 'stepA' || laminating == 'stepC'" >
+                <if test="laminating == 'stepA' || laminating == 'stepC'">
                     ogd.`group`,
                 </if>
                 rw.reporting_work_id,
@@ -1439,16 +1457,20 @@
                 rw.this_process,
                 rw.teams_groups_name,
                 rwd.order_number
-
             </otherwise>
         </choose>
+        ) t
+        WHERE 1 = 1
+        <if test="teamOutputDTO.workProcessName != null and teamOutputDTO.workProcessName != ''">
+            AND t.workProcessName REGEXP #{teamOutputDTO.workProcessName}
+        </if>
         ORDER BY
-        rw.this_process,
-        rw.process_id,
-        rwd.order_number,
-        rw.reporting_work_time,
-        rw.teams_groups_name
-        limit #{offset},#{pageSize};
+        t.this_process,
+        t.process_id,
+        t.order_number,
+        t.reporting_work_time,
+        t.teams_groups_name
+        LIMIT #{offset}, #{pageSize};
     </select>
 
     <select id="exportTeamOutputMp">
@@ -2341,6 +2363,22 @@
         <if test="workInProgressDTO.technologyNumber != null and workInProgressDTO.technologyNumber != ''">
             and ogd.technology_number regexp #{workInProgressDTO.technologyNumber}
         </if>
+        <if test="workInProgressDTO.quantity != null and workInProgressDTO.quantity != ''">
+            and od.quantity regexp #{workInProgressDTO.quantity}
+        </if>
+        <if test="workInProgressDTO.childWidth != null and workInProgressDTO.childWidth != ''">
+            and ogd.child_width regexp #{workInProgressDTO.childWidth}
+        </if>
+        <if test="workInProgressDTO.childHeight != null and workInProgressDTO.childHeight != ''">
+            and ogd.child_height regexp #{workInProgressDTO.childHeight}
+        </if>
+        <if test="workInProgressDTO.stockNum != null and workInProgressDTO.stockNum != ''">
+            and (d.numCounts + d.patchNumSum - d.numCount -d.broken_num) regexp #{workInProgressDTO.stockNum}
+        </if>
+        <if test="workInProgressDTO.stockArea != null and workInProgressDTO.stockArea != ''">
+            and ROUND(ogd.child_width * ogd.child_height * (d.numCounts + d.patchNumSum - d.numCount -
+            d.broken_num) / 1000000, 2) regexp #{workInProgressDTO.stockArea}
+        </if>
         <if test="workInProgressDTO.glassNumber != null and workInProgressDTO.glassNumber != ''">
             and ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') regexp #{workInProgressDTO.glassNumber}
         </if>
@@ -2973,30 +3011,50 @@
     
     
     <select id="processCardProgressCollectMp">
-       select * from (select b.product_name,
-            c.detail as 'glassName',
+       select * from (select
+              a.order_id,
+              a.order_number,
+              c.glass_group as 'group',
+              a.technology_number,
+            b.product_name,
+            c.detail as glass_child,
+            d.order_type,
             concat(a.process_id,'/',a.technology_number)  as processID,
             a.process_id,
-            a.quantity,
-            a.received_quantity,
-            round(sum(a.received_quantity*b.area),2) as received_area,
+            if(a.technology_number=1,sum(a.quantity-ifnull(a.termination_quantity,0)),0) as quantity,
+            sum(a.quantity)-ifnull(a.termination_quantity,0) as thisQuantity,/*鐢ㄤ簬鍒ゆ柇鏄惁鏀瑰彉棰滆壊*/
+            if(a.technology_number=1, round(sum((a.quantity-ifnull(a.termination_quantity,0)))*b.compute_area,2),0) as gross_area,
+            if(a.technology_number=1, sum(a.received_quantity),0) as inventory,
+            if(a.technology_number=1, round(sum(a.received_quantity*b.area),2),0) as inventoryArea,
 
-            a.technology_number
+            -- show
+            sum(a.quantity-ifnull(a.termination_quantity,0)) as quantityShow ,
+            round(sum((a.quantity-ifnull(a.termination_quantity,0)))*b.compute_area,2) as gross_areaShow,
+            sum(a.received_quantity) as inventoryShow,
+            round(sum(a.received_quantity*b.area),2) as inventoryAreaShow
+
+
+
+
             from pp.flow_card as a
             left join sd.order_detail as b
             on a.order_id = b.order_id and a.order_number = b.order_number
             left join sd.product_detail as c
             on c.prod_id = b.product_id and c.glass_sort = a.technology_number
+            LEFT JOIN sd.`order` as d
+            on a.order_id = d.order_id
             where a.order_id = #{orderId} group by processID
             ) as a
        left join (SELECT process_id,
                          technology_number,
                          sum(broken_num) as broken_num,
-                         concat('{',GROUP_CONCAT(reporting_work_nums),'}') as reporting_work_num
+                         concat('{',GROUP_CONCAT(reporting_work_nums),'}') as reportWorkQuantity,
+                         concat('{',GROUP_CONCAT(reporting_work_counts),'}') as reportWorkQuantityCount
                   from (select
                             opd.process_id,
                             opd.technology_number,
                             concat("\"", process, "\":\"", SUM(reporting_work_num), "\"") as  reporting_work_nums,
+                            concat("\"", process, "\":\"", SUM(reporting_work_num_count), "\"") as  reporting_work_counts,
                             sum(broken_num) as broken_num
                         from sd.order_process_detail as opd
                         where opd.order_id = #{orderId}
@@ -3006,4 +3064,93 @@
        order by a.process_id
 
     </select>
+
+    <select id="processCardProgressReportMp">
+        select a.product_name,
+               b.glass_child,
+               d.order_type,
+               concat(c.process_id, '/', c.technology_number) as process_id,
+               c.process_id as 'processId',
+                c.order_id,
+               c.order_number,
+               c.technology_number,
+               b.child_width,
+               b.child_height,
+               c.quantity,
+               c.quantity-ifnull(c.termination_quantity,0) as thisQuantity,/*鐢ㄤ簬鍒ゆ柇鏄惁鏀瑰彉棰滆壊*/
+               e.reportWorkQuantity,
+               e.reportWorkQuantityShow,
+               e.reportWorkQuantityCount,
+               e.reportWorkTime,
+               e.broken_num,
+               c.quantity-ifnull(c.termination_quantity,0) as glassQuantity,
+               c.quantity*a.area as gross_area,
+               c.quantity-ifnull(c.termination_quantity,0) as quantityShow,
+               (c.quantity-ifnull(c.termination_quantity,0))*a.compute_area as grossAreaShow,
+               ifnull(f.inventory, 0) as inventoryShow,
+               round(ifnull(f.inventory, 0) * a.compute_area, 2) as inventoryAreaShow, -- 搴撳瓨闈㈢Н
+               ifnull(dd.quantity, 0) as shippedQuantityShow, -- 鍙戣揣鏁伴噺
+               (ifnull(c.received_quantity, 0))*a.compute_area  as StorageAreaShow,-- 鍏ュ簱闈㈢Н
+
+               if(c.technology_number=1,(c.quantity-ifnull(c.termination_quantity,0))*a.compute_area,0) as grossArea,
+               if(c.technology_number=1,ifnull(f.inventory, 0) ,0)                        as inventory,
+               if(c.technology_number=1,round(ifnull(f.inventory, 0) * a.compute_area, 2),0)      as inventoryArea,
+               if(c.technology_number=1,ifnull(dd.quantity, 0) ,0)                          as shippedQuantity,
+               if(c.technology_number=1,(ifnull(c.received_quantity, 0))*a.compute_area,0)  as StorageArea,
+
+
+               ifnull(JSON_UNQUOTE(JSON_EXTRACT(a.other_columns, '$.S01')),'') AS glassNumber,
+               b.`group`
+
+        from pp.flow_card as c
+                 left join
+             sd.order_detail as a
+             on c.order_id = a.order_id
+                 and c.order_number = a.order_number
+                 left join sd.order_glass_detail as b
+                           on c.order_id = b.order_id
+                               and b.order_number = c.order_number
+                               and c.technology_number = b.technology_number
+                 left join sd.`order` as d
+                           on c.order_id = d.order_id
+                 left join mm.finished_goods_inventory as f
+                           on c.order_id = f.order_id and f.order_number = c.order_number
+                 left join sd.delivery_detail as dd on dd.order_id = a.order_id and dd.order_number = a.order_number
+                 left join (SELECT process_id,
+                                   order_number,
+                                   technology_number,
+                                   sum(a.broken_num) as broken_num,
+                                   concat('{',
+                                          GROUP_CONCAT(concat("\"", process, "\":\"", if(technology_number!=1 and (bd.nickname='stepD' || bd.nickname='stepB' ) ,0,reporting_work_num), "\"")),
+                                          '}'
+                                       )             as reportWorkQuantity,
+                                   concat('{',
+                                          GROUP_CONCAT(concat("\"", process, "\":\"", reporting_work_num, "\"")),
+                                          '}'
+                                       )             as reportWorkQuantityShow,
+                                   concat('{',
+                                          GROUP_CONCAT(concat("\"", process, "\":\"", reporting_work_num_count, "\"")),
+                                          '}'
+                                       )             as reportWorkQuantityCount,
+                                   concat('{',
+                                          GROUP_CONCAT(concat("\"", process, "\":\"", IFNULL(date(update_time),''), "\"")),
+                                          '}'
+                                       )             as reportWorkTime
+                            FROM sd.order_process_detail as a
+                                     left join (SELECT DISTINCT basic_name,nickname from sd.basic_data as bd where  bd.basic_category = 'process') as bd
+                                               on a.process = bd.basic_name
+                            where a.order_id = #{orderId}
+                            GROUP BY process_id, a.order_number, a.technology_number
+
+
+        ) as e
+                           on e.process_id = c.process_id
+                               and e.technology_number = c.technology_number
+                               and e.order_number = c.order_number
+        where a.order_id = #{orderId} and d.create_order>0 and c.quantity-ifnull(c.termination_quantity,0)>0
+        group by c.order_number,
+                 c.technology_number,
+                 c.process_id
+        order by c.process_id, c.order_number, c.technology_number
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0