From 13fd47c5aa585b74bfc8b77722bde3f7a2399587 Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期四, 21 五月 2026 10:26:42 +0800
Subject: [PATCH] refactor(invoice): 删除invoice_registration  invoice_registration_product  invoice_ledger  invoice_ledger_file

---
 src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml |   65 ++++++++++----------------------
 1 files changed, 20 insertions(+), 45 deletions(-)

diff --git a/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml b/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
index 0b29502..53ba9bc 100644
--- a/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
+++ b/src/main/resources/mapper/purchase/InvoicePurchaseMapper.xml
@@ -6,31 +6,28 @@
 
 
     <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,
-        sl.id,
-        pl.id as pl_id,
+        SELECT
+        sl.sales_contract_no AS customerContractNo,
         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
+        sl.contract_amount AS contract_amount,
+        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 *
@@ -47,6 +44,7 @@
                                 LEFT JOIN invoice_registration_product pr ON pr.id = il.invoice_registration_product_id
                        WHERE il.invoice_no IS NOT NULL
                          AND invoice_type = '澧炰笓绁�'
+                         AND DATE_FORMAT(il.invoice_date, '%Y-%m') IS NOT NULL  -- 鏂板锛氳繃婊onth涓篘ULL鐨勬儏
                        GROUP BY DATE_FORMAT(il.invoice_date, '%Y-%m')
                    ) a1
                        LEFT JOIN (
@@ -105,42 +103,19 @@
                            LEFT JOIN invoice_registration_product pr ON pr.id = il.invoice_registration_product_id
                   WHERE il.invoice_no IS NOT NULL
                     AND invoice_type = '澧炰笓绁�'
+                    AND DATE_FORMAT(il.invoice_date, '%Y-%m') IS NOT NULL  -- 鏂板锛氳繃婊onth涓篘ULL鐨勬儏
                   GROUP BY DATE_FORMAT(il.invoice_date, '%Y-%m')
               ) a1 ON a1.month = a2.month
               WHERE a1.month IS NULL
               ORDER BY month
              )as a
         <where>
+            a.month is not null
             <if test="month != null">
                 and a.month = #{month}
             </if>
         </where>
 
-    </select>
-    <select id="listVat1" resultType="com.ruoyi.purchase.dto.VatDto">
-        #             SELECT
-#                 DATE_FORMAT(il.invoice_date, '%Y-%m') AS month,
-#                 ROUND(SUM(pr.invoice_amount - pr.invoice_amount / (1 + pr.tax_rate / 100)), 2) AS tax_amount
-#             FROM invoice_ledger il
-#                      LEFT JOIN invoice_registration_product pr ON pr.id = il.invoice_registration_product_id
-#             WHERE il.invoice_no IS NOT NULL
-#               AND invoice_type = '澧炰笓绁�'
-#             GROUP BY DATE_FORMAT(il.invoice_date, '%Y-%m')
-#             ORDER BY month;
-#         select DATE_FORMAT(a.issue_date, '%Y-%m'), sum(a.invoice_amount) as xTaxAmount
-#         from (SELECT distinct pr.id,
-#                               tr.issue_date,
-#                               ROUND(pr.tickets_amount / (1 + pr.tax_rate / 100), 2) AS un_tickets_price,
-#                               ROUND(pr.tickets_amount - pr.tickets_amount / (1 + pr.tax_rate / 100),
-#                                     2)                                              AS invoice_amount
-#               FROM product_record pr
-#                        LEFT JOIN purchase_ledger pl ON pl.id = pr.purchase_ledger_id
-#                        LEFT JOIN sales_ledger sl ON sl.id = pl.sales_ledger_id
-#                        LEFT JOIN ticket_registration tr ON tr.purchase_ledger_id = pl.id
-#                        LEFT JOIN product_model pm ON pm.id = pr.product_model_id
-#               WHERE type = 2
-#                 and tr.invoice_number is not null) a
-#         GROUP BY DATE_FORMAT(a.issue_date, '%Y-%m')
     </select>
 
 </mapper>

--
Gitblit v1.9.3