From bb1befa2a8abae3f75cc71b524c46a6d206cb46b Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期五, 30 一月 2026 10:47:01 +0800
Subject: [PATCH] feat(production): 添加生产核算功能和相关接口

---
 src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml |   32 ++++++++++++++++++++++++++------
 1 files changed, 26 insertions(+), 6 deletions(-)

diff --git a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
index 9528922..ac3ccc5 100644
--- a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
+++ b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
@@ -24,9 +24,9 @@
         LEFT JOIN sales_ledger T1 ON T1.id = t4.sales_ledger_id
         left join sales_ledger_product t3 on t4.sales_ledger_product_id = t3.id
         <where>
-            1 = 1
+            t3.type = 1
             <if test="salesLedgerDto.schedulingUserName != null and salesLedgerDto.schedulingUserName != '' ">
-                AND  t4.scheduling_user_uame LIKE CONCAT('%',#{salesLedgerDto.schedulingUserName},'%')
+                AND  t4.scheduling_user_name LIKE CONCAT('%',#{salesLedgerDto.schedulingUserName},'%')
             </if>
             <if test="salesLedgerDto.customerName != null and salesLedgerDto.customerName != '' ">
                 AND  T1.customer_name LIKE CONCAT('%',#{salesLedgerDto.customerName},'%')
@@ -40,14 +40,34 @@
             <if test="salesLedgerDto.projectName != null and salesLedgerDto.projectName != '' ">
                 AND T1.project_name LIKE CONCAT('%',#{salesLedgerDto.projectName},'%')
             </if>
-            <if test="salesLedgerDto.schedulingDateStart != null and salesLedgerDto.schedulingDateStart != '' ">
+            <if test="salesLedgerDto.entryDateStart != null and salesLedgerDto.entryDateStart != '' ">
                 AND t4.scheduling_date &gt;= DATE_FORMAT(#{salesLedgerDto.entryDateStart},'%Y-%m-%d')
             </if>
-            <if test="salesLedgerDto.schedulingDateEnd != null and salesLedgerDto.schedulingDateEnd != '' ">
+            <if test="salesLedgerDto.entryDateEnd != null and salesLedgerDto.entryDateEnd != '' ">
                 AND  t4.scheduling_date &lt;= DATE_FORMAT(#{salesLedgerDto.entryDateEnd},'%Y-%m-%d')
             </if>
         </where>
         group by t4.id
-        order by t4.update_time desc
+        order by t4.scheduling_date desc
     </select>
-</mapper>
\ No newline at end of file
+    <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
+        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
+        <where>
+            <if test="ew.schedulingUserName != null and ew.schedulingUserName !=''" >
+                and slpa.scheduling_user_name  = #{ew.schedulingUserName}
+            </if>
+        </where>
+        GROUP BY slpa.scheduling_user_name
+
+    </select>
+
+</mapper>

--
Gitblit v1.9.3