From a1160706d2940bcbd38233731691a999be1d4024 Mon Sep 17 00:00:00 2001
From: yaowanxin <3588231647@qq.com>
Date: 星期六, 11 十月 2025 11:28:38 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml | 59 +++++++++++++++++++++++++++++++++++++++--------------------
1 files changed, 39 insertions(+), 20 deletions(-)
diff --git a/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml b/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
index 3d91391..413f293 100644
--- a/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
+++ b/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
@@ -6,29 +6,48 @@
<select id="selectPurchaseReport" resultType="com.ruoyi.purchase.dto.InvoicePurchaseReportDto">
- select A.*,
- FORMAT(A.contract_amount-A.sale_tax_exclusive_total_price-A.purchase_amount+A.tax_exclusive_total_price,2) as balance_amount
- from (select sl.customer_contract_no,
+ SELECT
+ A.*,
+ FORMAT(A.sales_tax_amount - A.purchase_tax_amount, 2) AS balance_amount
+ FROM (
+ SELECT
+ sl.customer_contract_no,
sl.id,
- pl.id as pl_id,
+ pl.id AS pl_id,
sl.customer_name,
sl.project_name,
- sl.contract_amount,
- pl.contract_amount as purchase_amount,
- sum(slp.tax_exclusive_total_price) /count(slp.id) as sale_tax_exclusive_total_price,
- sum(slp1.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
- from purchase_ledger pl
- left join sales_ledger sl on pl.sales_ledger_id = sl.id
- left join sales_ledger_product slp on slp.sales_ledger_id = sl.id and slp.type = 1
- left join sales_ledger_product slp1 on slp1.sales_ledger_id = pl.id and slp1.type = 2
- group by sl.customer_contract_no, sl.customer_name, sl.project_name, sl.contract_amount, pl.contract_amount,sl.id,pl.id
- having sl.customer_contract_no is not null) A
+ slp.tax_inclusive_total_price - slp.tax_exclusive_total_price AS contract_amount,
+ SUM(slp1.tax_inclusive_total_price - slp1.tax_exclusive_total_price) AS purchase_amount,
+ (slp.tax_exclusive_total_price) / COUNT(slp.id) AS sale_tax_exclusive_total_price,
+ SUM(slp1.tax_exclusive_total_price) AS tax_exclusive_total_price,
+ (slp.tax_inclusive_total_price - slp.tax_exclusive_total_price) -
+ SUM(slp1.tax_inclusive_total_price - slp1.tax_exclusive_total_price) AS balance,
+ CONCAT(
+ FORMAT(
+ ((slp.tax_inclusive_total_price - slp.tax_exclusive_total_price) -
+ SUM(slp1.tax_inclusive_total_price - slp1.tax_exclusive_total_price)) /
+ (slp.tax_inclusive_total_price - slp.tax_exclusive_total_price) * 100,
+ 2),
+ '%'
+ ) AS balance_ratio,
+ (slp.tax_inclusive_total_price - slp.tax_exclusive_total_price) AS sales_tax_amount,
+ SUM(slp1.tax_inclusive_total_price - slp1.tax_exclusive_total_price) AS purchase_tax_amount
+ FROM
+ purchase_ledger pl
+ LEFT JOIN
+ sales_ledger sl ON pl.sales_ledger_id = sl.id
+ LEFT JOIN
+ sales_ledger_product slp ON slp.sales_ledger_id = sl.id AND slp.type = 1
+ LEFT JOIN
+ sales_ledger_product slp1 ON slp1.sales_ledger_id = pl.id AND slp1.type = 2
+ GROUP BY
+ sl.customer_contract_no, sl.customer_name, sl.project_name, sl.id, pl.id
+ HAVING
+ sl.customer_contract_no IS NOT NULL
+ ) A
<where>
<if test="c.customerName != null and c.customerName != ''">
- and sl.customer_name like concat('%',#{c.customerName},'%')
+ AND A.customer_name LIKE CONCAT('%', #{c.customerName}, '%')
</if>
</where>
</select>
@@ -112,7 +131,7 @@
)as a
<where>
<if test="month != null">
- and a.month = date_format(#{month})
+ and a.month = #{month}
</if>
</where>
@@ -143,4 +162,4 @@
# GROUP BY DATE_FORMAT(a.issue_date, '%Y-%m')
</select>
-</mapper>
\ No newline at end of file
+</mapper>
--
Gitblit v1.9.3