From dd51f856dc7eb6255a5e927c47fa35281216f315 Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期五, 03 四月 2026 18:37:23 +0800
Subject: [PATCH] yys

---
 src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml |   37 +++++++++++++++++++------------------
 1 files changed, 19 insertions(+), 18 deletions(-)

diff --git a/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml b/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
index 731b5c5..96e0388 100644
--- a/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
+++ b/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
@@ -6,28 +6,29 @@
 
 
     <select id="selectPurchaseReport" resultType="com.ruoyi.purchase.dto.InvoicePurchaseReportDto">
-        select sl.customer_contract_no,
-               sl.customer_name,
-               sl.project_name,
-               sl.contract_amount,
-               pl.contract_amount as purchase_amount,
-               sum(slp.tax_exclusive_total_price) as sale_tax_exclusive_total_price,
-               sum(pr.tax_exclusive_total_price) as tax_exclusive_total_price,
-               (sl.contract_amount-pl.contract_amount) as balance,
-        CONCAT(FORMAT((sl.contract_amount - pl.contract_amount) / sl.contract_amount * 100, 2), '%') AS balance_ratio,
-               sl.contract_amount-sum(slp.tax_exclusive_total_price)-(pl.contract_amount-sum(pr.tax_exclusive_total_price)) as balance_amount
-        from purchase_ledger pl
-                 left join sales_ledger sl on pl.sales_ledger_id = sl.id
-                 left join product_record pr on pr.purchase_ledger_id = pl.id
-                 left join sales_ledger_product slp on slp.sales_ledger_id = sl.id
-
-        group by sl.customer_contract_no, sl.customer_name, sl.project_name, sl.contract_amount, pl.contract_amount
-        having sl.customer_contract_no is not null
+        SELECT
+        sl.sales_contract_no AS customerContractNo,
+        sl.customer_name,
+        sl.contract_amount AS contract_amount,
+        sl.project_name,
+        SUM( pl.contract_amount ) AS purchase_amount,
+        (
+        sl.contract_amount - SUM( pl.contract_amount )) AS balance,
+        CONCAT( ROUND( ( sl.contract_amount - SUM( pl.contract_amount )) / sl.contract_amount * 100, 1 ), '%' ) AS balance_ratio
+        FROM
+        sales_ledger sl
+        INNER JOIN purchase_ledger pl ON sl.sales_contract_no = pl.sales_contract_no
         <where>
             <if test="c.customerName != null and c.customerName != ''">
-                and sl.customer_name like concat('%',#{c.customerName},'%')
+                AND sl.customer_name LIKE CONCAT('%', #{c.customerName}, '%')
             </if>
         </where>
+        GROUP BY
+        sl.sales_contract_no,
+        sl.customer_name,
+        sl.contract_amount
+        ORDER BY
+        sl.sales_contract_no
     </select>
     <select id="listVat" resultType="com.ruoyi.purchase.dto.VatDto">
         select *

--
Gitblit v1.9.3