From 2d03ec79e1892248b520cf097e8a58dd82a4892f Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期五, 22 五月 2026 15:19:15 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_天津_阳光彩印' into dev_天津_阳光彩印

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

diff --git a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
index 3535b77..556f6f0 100644
--- a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
+++ b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
@@ -22,7 +22,7 @@
         FROM
         sales_ledger_production_accounting t4
         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
+        left join sales_ledger_product t3 on t4.sales_ledger_product_id = t3.id and t3.type = 1
         <where>
             t3.type = 1
             <if test="salesLedgerDto.schedulingUserName != null and salesLedgerDto.schedulingUserName != '' ">
@@ -50,26 +50,34 @@
         group by t4.id
         order by t4.scheduling_date desc
     </select>
-    <select id="pageProductionAccounting"
-            resultType="com.ruoyi.production.dto.SalesLedgerProductionAccountingDto">
+    <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(ppout.quantity) AS output_num,
         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
+        END, 2
         ),
         '%'
-        ) as output_rate
+        ) AS output_rate, GROUP_CONCAT(
+        CONCAT(
+        IFNULL(slpa.work_hour, 0),
+        '|$|',
+        IFNULL(dl.device_name, '鏈煡鏈哄彴')
+        )
+        ORDER BY slpa.create_time
+        SEPARATOR '>>>'
+        ) AS device_work_info
         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.product_main_id = ppm.id
+        LEFT JOIN production_product_output ppout
+        ON ppm.id = ppout.product_main_id
+        left join device_ledger dl on dl.id = slpa.device_id
         <where>
             <if test="ew.schedulingUserName != null and ew.schedulingUserName !=''">
                 and slpa.scheduling_user_name = #{ew.schedulingUserName}
@@ -82,10 +90,8 @@
                 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
-
     </select>
 
     <select id="selectDailyWagesStats" resultType="java.util.Map">
@@ -105,6 +111,19 @@
         GROUP BY DATE(ppout.create_time)
         ORDER BY DATE(ppout.create_time);
     </select>
+    <select id="getByUserId" resultType="com.ruoyi.production.dto.UserAccountDto">
+        select
+            slpa.scheduling_user_id as user_id,
+            pp.type,
+            sum(case when pp.type = 0 then slpa.work_hours else 0 end) as account,
+            sum(case when pp.type = 1 then slpa.work_hours else 0 end) as accountBalance
+        from sales_ledger_production_accounting slpa
+                 left join product_process pp on pp.name = slpa.process
+        where  slpa.scheduling_user_id = #{ew.userId}
+          and slpa.scheduling_date like concat(#{ew.date}, '%')
+        group by slpa.scheduling_user_id
+
+    </select>
 
 
 </mapper>

--
Gitblit v1.9.3