From 174cc2a8aa52f00334e0e9a3a0ea91b2e3e7acd3 Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期四, 30 十月 2025 16:20:41 +0800
Subject: [PATCH] 修改次破报表翻页汇总不正确问题

---
 north-glass-erp/src/main/resources/mapper/pp/Report.xml |   36 ++++++++++++++++++++++++++++--------
 1 files changed, 28 insertions(+), 8 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 215ba9a..ddce89e 100644
--- a/north-glass-erp/src/main/resources/mapper/pp/Report.xml
+++ b/north-glass-erp/src/main/resources/mapper/pp/Report.xml
@@ -274,7 +274,8 @@
                rw.this_process,
                JSON_UNQUOTE( JSON_EXTRACT( od.other_columns, '$.S01' )) AS code,
                CONCAT(rw.process_id,'/',GROUP_CONCAT(distinct dd.technology_number SEPARATOR '')) as process_id,
-               rw.creator
+               rw.creator,
+               rw.reporting_work_id
         from
             sd.`order` as o left join sd.order_detail as od on o.order_id=od.order_id
                              left join sd.order_glass_detail as ogd on ogd.order_id=od.order_id and ogd.order_number=od.order_number
@@ -324,6 +325,9 @@
         <if test="crossProcessBreakingDTO.code != null and crossProcessBreakingDTO.code != ''">
             and ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') regexp #{crossProcessBreakingDTO.code}
         </if>
+        <if test="crossProcessBreakingDTO.reportingWorkId != null and crossProcessBreakingDTO.reportingWorkId != ''">
+            and rw.reporting_work_id regexp #{crossProcessBreakingDTO.reportingWorkId}
+        </if>
         GROUP BY dd.id
         order by dd.id desc
         limit #{offset},#{pageSize}
@@ -346,7 +350,8 @@
         rw.this_process,
         JSON_UNQUOTE( JSON_EXTRACT( od.other_columns, '$.S01' )) AS code,
         CONCAT(rw.process_id,'/',GROUP_CONCAT(distinct dd.technology_number SEPARATOR '')) as process_id,
-        rw.creator
+        rw.creator,
+        rw.reporting_work_id
         from
         sd.`order` as o left join sd.order_detail as od on o.order_id=od.order_id
         left join sd.order_glass_detail as ogd on ogd.order_id=od.order_id and ogd.order_number=od.order_number
@@ -396,6 +401,9 @@
         <if test="crossProcessBreakingDTO.code != null and crossProcessBreakingDTO.code != ''">
             and ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') regexp #{crossProcessBreakingDTO.code}
         </if>
+        <if test="crossProcessBreakingDTO.reportingWorkId != null and crossProcessBreakingDTO.reportingWorkId != ''">
+            and rw.reporting_work_id regexp #{crossProcessBreakingDTO.reportingWorkId}
+        </if>
         GROUP BY dd.id
         order by dd.id desc
         limit #{offset},#{pageSize}
@@ -412,11 +420,12 @@
                  left join sd.order_glass_detail as ogd
                            on ogd.order_id = o.order_id and ogd.order_number = dd.order_number
                                and ogd.technology_number and dd.technology_number
+        left join sd.order_detail as od on o.order_id = od.order_id and od.order_number=ogd.order_number
         where date(rw.reporting_work_time) >= #{startDate}
           and date(rw.reporting_work_time) &lt;= #{endDate}
           and rw.this_worn_quantity > 0
           and dd.available = 0
-          and reviewed_state != 2
+          and rw.reviewed_state>=0
           and rw.this_process != dd.responsible_process
         <if test="crossProcessBreakingDTO.code != null and crossProcessBreakingDTO.code != ''">
             and JSON_UNQUOTE( JSON_EXTRACT( od.other_columns, '$.S01' )) regexp #{crossProcessBreakingDTO.code}
@@ -451,6 +460,9 @@
         <if test="crossProcessBreakingDTO.code != null and crossProcessBreakingDTO.code != ''">
             and ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') regexp #{crossProcessBreakingDTO.code}
         </if>
+        <if test="crossProcessBreakingDTO.reportingWorkId != null and crossProcessBreakingDTO.reportingWorkId != ''">
+            and rw.reporting_work_id regexp #{crossProcessBreakingDTO.reportingWorkId}
+        </if>
         order by dd.id desc
     </select>
 
@@ -465,6 +477,7 @@
         left join sd.order_glass_detail as ogd
         on ogd.order_id = o.order_id and ogd.order_number = dd.order_number
         and ogd.technology_number and dd.technology_number
+        left join sd.order_detail as od on o.order_id = od.order_id and od.order_number=ogd.order_number
         where date(rw.reporting_work_time) >= #{startDate}
         and date(rw.reporting_work_time) &lt;= #{endDate}
         and rw.this_worn_quantity > 0
@@ -760,7 +773,8 @@
         ogd.child_height,
         ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') AS glassNumber,
         rw.this_process,
-        rw.creator
+        rw.creator,
+        rw.reporting_work_id
         FROM
         sd.ORDER AS o
         LEFT JOIN sd.order_glass_detail AS ogd ON ogd.order_id = o.order_id
@@ -816,6 +830,9 @@
         <if test="damageReportDTO.creator != null and damageReportDTO.creator != ''">
             and rw.creator regexp #{damageReportDTO.creator}
         </if>
+        <if test="damageReportDTO.reportingWorkId != null and damageReportDTO.reportingWorkId != ''">
+            and rw.reporting_work_id regexp #{damageReportDTO.reportingWorkId}
+        </if>
         GROUP BY
         dd.id
         limit #{offset},#{pageSize};
@@ -835,7 +852,7 @@
         WHERE
         rw.reporting_work_time >= #{selectTime1}
         AND rw.reporting_work_time &lt;  #{selectTime2}
-        AND dd.available = 0
+        AND dd.available = 0 and rw.reviewed_state>=0
         <if test="damageReportDTO.orderId != null and damageReportDTO.orderId != ''">
             and o.order_id regexp #{damageReportDTO.orderId}
         </if>
@@ -1209,7 +1226,8 @@
                rw.this_process,
                JSON_UNQUOTE( JSON_EXTRACT( od.other_columns, '$.S01' )) AS code,
                CONCAT(rw.process_id,'/',GROUP_CONCAT(distinct dd.technology_number SEPARATOR '')) as process_id,
-               rw.creator
+               rw.creator,
+               rw.reporting_work_id
         from damage_details as dd
                  left join reporting_work as rw
                            on rw.reporting_work_id = dd.reporting_work_id
@@ -1245,7 +1263,8 @@
                rw.this_process,
                JSON_UNQUOTE( JSON_EXTRACT( od.other_columns, '$.S01' )) AS code,
                CONCAT(rw.process_id,'/',GROUP_CONCAT(distinct dd.technology_number SEPARATOR '')) as process_id,
-               rw.creator
+               rw.creator,
+               rw.reporting_work_id
         from damage_details as dd
                  left join reporting_work as rw
                            on rw.reporting_work_id = dd.reporting_work_id
@@ -1286,7 +1305,8 @@
                ogd.child_height,
                ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S01')),'') AS glassNumber,
                rw.this_process,
-               rw.creator
+               rw.creator,
+               rw.reporting_work_id
         FROM sd.ORDER AS o
                  LEFT JOIN sd.order_glass_detail AS ogd ON ogd.order_id = o.order_id
                  LEFT JOIN reporting_work AS rw ON rw.order_id = o.order_id

--
Gitblit v1.8.0