From 981d05f97e9eaf273ee82f847a365b63ed6eaed1 Mon Sep 17 00:00:00 2001
From: maven <2163098428@qq.com>
Date: 星期一, 08 十二月 2025 09:50:32 +0800
Subject: [PATCH] yys  修改财务bug

---
 src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java |   68 +++++++++++++++++++++++++++-------
 1 files changed, 54 insertions(+), 14 deletions(-)

diff --git a/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java b/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
index a3c775f..446efca 100644
--- a/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
+++ b/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
@@ -22,6 +22,7 @@
 
 import javax.servlet.http.HttpServletResponse;
 import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.time.DayOfWeek;
 import java.time.LocalDate;
 import java.time.format.DateTimeFormatter;
@@ -56,31 +57,70 @@
     @Override
     public AccountDto report(DateQueryDto dateQueryDto) {
         AccountDto accountDto = new AccountDto();
-        //鑾峰彇璇ユ鏃堕棿鍐呯殑鎵�鏈夋敹鍏�
-        List<AccountDto2> accountIncomes =accountIncomeMapper.report(dateQueryDto);
+
+        // 鑾峰彇璇ユ鏃堕棿鍐呯殑鎵�鏈夋敹鍏�
+        List<AccountDto2> accountIncomes = accountIncomeMapper.report(dateQueryDto);
+        if (accountIncomes == null) {
+            accountIncomes = Collections.emptyList();
+        }
 
         Long incomeNumber = accountIncomeMapper.selectCount(Wrappers.<AccountIncome>lambdaQuery()
                 .between(AccountIncome::getIncomeDate, dateQueryDto.getEntryDateStart(), dateQueryDto.getEntryDateEnd()));
         accountDto.setIncomeNumber(incomeNumber);
-        BigDecimal totalIncome = accountIncomes.stream().map(AccountDto2::getAccount).reduce(BigDecimal.ZERO, BigDecimal::add);
+
+        BigDecimal totalIncome = BigDecimal.ZERO;
+        for (AccountDto2 item : accountIncomes) {
+            if (item.getAccount() != null) {
+                totalIncome = totalIncome.add(item.getAccount());
+            }
+        }
         accountDto.setTotalIncome(totalIncome);
-        accountIncomes.stream().forEach(accountDto2 -> {
-            accountDto2.setProportion(accountDto2.getAccount().divide(totalIncome,2,BigDecimal.ROUND_HALF_UP));
-        });
+        if (totalIncome.compareTo(BigDecimal.ZERO) != 0) {
+            for (AccountDto2 item : accountIncomes) {
+                if (item.getAccount() != null) {
+                    item.setProportion(item.getAccount().divide(totalIncome, 2, RoundingMode.HALF_UP));
+                }
+            }
+        } else {
+            for (AccountDto2 item : accountIncomes) {
+                item.setProportion(BigDecimal.ZERO);
+            }
+        }
         accountDto.setIncomeType(accountIncomes);
-        //鑾峰彇璇ユ鏃堕棿鍐呯殑鎵�鏈夋敮鍑�
-        List<AccountDto2> accountExpenses =accountExpenseMapper.report(dateQueryDto);
-        accountDto.setExpenseType(accountExpenses);
+        // 鑾峰彇璇ユ鏃堕棿鍐呯殑鎵�鏈夋敮鍑�
+        List<AccountDto2> accountExpenses = accountExpenseMapper.report(dateQueryDto);
+        if (accountExpenses == null) {
+            accountExpenses = Collections.emptyList();
+        }
+
+        accountDto.setExpenseType(accountExpenses); // 绉婚櫎浜嗕笅鏂归噸澶嶇殑涓�琛�
+
         Long expenseNumber = accountExpenseMapper.selectCount(Wrappers.<AccountExpense>lambdaQuery()
                 .between(AccountExpense::getExpenseDate, dateQueryDto.getEntryDateStart(), dateQueryDto.getEntryDateEnd()));
         accountDto.setExpenseNumber(expenseNumber);
-        BigDecimal totalExpense = accountExpenses.stream().map(AccountDto2::getAccount).reduce(BigDecimal.ZERO, BigDecimal::add);
+
+        BigDecimal totalExpense = BigDecimal.ZERO;
+        for (AccountDto2 item : accountExpenses) {
+            if (item.getAccount() != null) {
+                totalExpense = totalExpense.add(item.getAccount());
+            }
+        }
         accountDto.setTotalExpense(totalExpense);
-        accountExpenses.stream().forEach(accountDto2 -> {
-            accountDto2.setProportion(accountDto2.getAccount().divide(totalExpense,2,BigDecimal.ROUND_HALF_UP));
-        });
+
+        if (totalExpense.compareTo(BigDecimal.ZERO) != 0) {
+            for (AccountDto2 item : accountExpenses) {
+                if (item.getAccount() != null) {
+                    item.setProportion(item.getAccount().divide(totalExpense, 2, RoundingMode.HALF_UP));
+                }
+            }
+        } else {
+            for (AccountDto2 item : accountExpenses) {
+                item.setProportion(BigDecimal.ZERO);
+            }
+        }
         accountDto.setExpenseType(accountExpenses);
-        //鍑�鏀跺叆
+
+        // 鍑�鏀跺叆
         BigDecimal netRevenue = totalIncome.subtract(totalExpense);
         accountDto.setNetRevenue(netRevenue);
         return accountDto;

--
Gitblit v1.9.3