From f7649c532163847914e3591236e77c99fb68e1a8 Mon Sep 17 00:00:00 2001
From: gongchunyi <deslre0381@gmail.com>
Date: 星期五, 30 一月 2026 16:42:00 +0800
Subject: [PATCH] Merge branch 'dev_New' of http://114.132.189.42:9002/r/product-inventory-management-after into dev_New

---
 src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml |   36 +++++++++++++++++++++++++++---------
 1 files changed, 27 insertions(+), 9 deletions(-)

diff --git a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
index 42090a7..31e95de 100644
--- a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
+++ b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
@@ -53,18 +53,36 @@
     <select id="pageProductionAccounting"
             resultType="com.ruoyi.production.dto.SalesLedgerProductionAccountingDto">
         SELECT
-            slpa.scheduling_user_id,
-            slpa.scheduling_user_name,
-               sum(ppout.quantity) as output_num,
-               sum(slpa.finished_num * work_hours) as  wages,
-               SUM(slpa.finished_num) / SUM(ppout.quantity) as output_rate
+        slpa.scheduling_user_id,
+        slpa.scheduling_user_name,
+        sum(ppout.quantity) as output_num,
+        sum(slpa.finished_num * work_hours) as wages,
+        CONCAT(
+        ROUND(
+        CASE
+        WHEN SUM(ppout.quantity) = 0 OR SUM(ppout.quantity) IS NULL THEN 0
+        ELSE SUM(slpa.finished_num) * 100.0 / SUM(ppout.quantity)
+        END,
+        2
+        ),
+        '%'
+        ) as output_rate
         FROM sales_ledger_production_accounting slpa
-                 LEFT JOIN production_product_main ppm ON slpa.sales_ledger_work_id = ppm.id
-                 LEFT JOIN production_product_output ppout ON ppm.id = ppout.product_main_id
+        LEFT JOIN production_product_main ppm ON slpa.sales_ledger_work_id = ppm.id
+        LEFT JOIN production_product_output ppout ON ppm.id = ppout.product_main_id
         <where>
-            <if test="ew.schedulingUserName != null and ew.schedulingUserName !=''" >
-                and slpa.scheduling_user_name  = #{ew.schedulingUserName}
+            <if test="ew.schedulingUserName != null and ew.schedulingUserName !=''">
+                and slpa.scheduling_user_name = #{ew.schedulingUserName}
             </if>
+            <if test="ew.entryDate != null ">
+                and slpa.scheduling_date >= #{ew.entryDate}
+                and slpa.scheduling_date &lt; DATE_ADD(DATE(#{ew.entryDate}), INTERVAL 1 DAY)
+            </if>
+            <if test="ew.entryDateStart != null and ew.entryDateEnd != null">
+                and slpa.scheduling_date >= #{ew.entryDateStart}
+                and slpa.scheduling_date &lt; DATE_ADD(DATE(#{ew.entryDateEnd}), INTERVAL 1 DAY)
+            </if>
+
         </where>
         GROUP BY slpa.scheduling_user_name
 

--
Gitblit v1.9.3