From b3b17b231e2f2840332ce6eb96f791865fdec6d5 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期一, 14 四月 2025 16:38:16 +0800
Subject: [PATCH] 代码优化
---
 pipIrr-platform/pipIrr-web/pipIrr-web-statistics/src/main/java/com/dy/pipIrrStatistics/statistics/StClientAmountSv.java |  324 ++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 305 insertions(+), 19 deletions(-)
diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-statistics/src/main/java/com/dy/pipIrrStatistics/statistics/StClientAmountSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-statistics/src/main/java/com/dy/pipIrrStatistics/statistics/StClientAmountSv.java
index 3b793ba..c92c250 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-statistics/src/main/java/com/dy/pipIrrStatistics/statistics/StClientAmountSv.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-statistics/src/main/java/com/dy/pipIrrStatistics/statistics/StClientAmountSv.java
@@ -1,10 +1,10 @@
 package com.dy.pipIrrStatistics.statistics;
 
 import com.dy.pipIrrGlobal.daoRm.RmClientAmountDayMapper;
+import com.dy.pipIrrGlobal.daoSt.StClientAmountDayMapper;
 import com.dy.pipIrrGlobal.daoSt.StClientAmountMonthMapper;
 import com.dy.pipIrrGlobal.daoSt.StClientAmountYearMapper;
-import com.dy.pipIrrGlobal.pojoSt.StClientAmountMonth;
-import com.dy.pipIrrGlobal.pojoSt.StClientAmountYear;
+import com.dy.pipIrrGlobal.pojoSt.*;
 import com.dy.pipIrrGlobal.voSt.VoClientAmountStatistics;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
@@ -24,33 +24,56 @@
     protected RmClientAmountDayMapper rmClientAmountDayDao;
 
     @Autowired
+    protected StClientAmountDayMapper stClientAmountDayDao;
+
+    @Autowired
     protected StClientAmountMonthMapper stClientAmountMonthDao ;
 
     @Autowired
     protected StClientAmountYearMapper stClientAmountYearDao ;
 
     /**
+     * 鏃ョ粺璁�---鍐滄埛鐢ㄦ按閲忓強閲戦锛岀敱绾靛瀷鏁版嵁鏀规垚琛屽瀷鏁版嵁
+     */
+    @Transactional
+    protected void statisticsDay(Integer statisticsYear, Integer statisticsMonth, Integer statisticsDay, Long statisticsStartId, Long statisticsEndId){
+        List<VoClientAmountStatistics> list = rmClientAmountDayDao.statisticsByClient(statisticsStartId, statisticsEndId) ;
+        if(list != null && list.size() > 0){
+            List<StClientAmountDay> listOfDay = stClientAmountDayDao.selectByYearAndMonthAndDay(statisticsYear, statisticsMonth) ;
+            for(VoClientAmountStatistics vo : list){
+                StClientAmountDay po = this.getDayDataOfClient(listOfDay, vo.clientId) ;
+                if(po == null){
+                    po = new StClientAmountDay() ;
+                    po.clientId = vo.clientId ;
+                    po.year = statisticsYear ;
+                    po.month = statisticsMonth ;
+                }
+                this.setValueOfDayOfMonth(statisticsDay, vo, po);
+                if(po.id == null) {
+                    stClientAmountDayDao.insert(po);
+                }else{
+                    stClientAmountDayDao.updateByPrimaryKeySelective(po) ;
+                }
+            }
+        }
+    }
+
+    /**
      * 鏈堢粺璁�---鍐滄埛鐢ㄦ按閲忓強閲戦
      */
     @Transactional
     protected void statisticsMonth(Integer statisticsYear, Integer statisticsMonth, Long statisticsStartId, Long statisticsEndId){
-        List<VoClientAmountStatistics> list = rmClientAmountDayDao.statisticsByClient(statisticsStartId, statisticsEndId) ;
+        List<VoClientAmountStatistics> list = stClientAmountDayDao.statisticsByClient(statisticsYear, statisticsMonth) ;
         if(list != null && list.size() > 0){
+            List<StClientAmountMonth> listOfMonth = stClientAmountMonthDao.selectByYear(statisticsYear) ;
             for(VoClientAmountStatistics vo : list){
-                List<StClientAmountMonth> listOfMonth = stClientAmountMonthDao.selectByClientIdAndYearAndMonth(vo.clientId, statisticsYear, statisticsMonth) ;
-                StClientAmountMonth po = null ;
-                if(listOfMonth != null && listOfMonth.size() > 0){
-                    //绋嬪簭閫昏緫鎺у埗涓婏紝闆嗗悎涓彧鏈変竴涓璞�
-                    po = listOfMonth.get(0) ;
-                }
+                 StClientAmountMonth po = this.getMonthDataOfClient(listOfMonth, vo.clientId) ;
                 if(po == null) {
                     po = new StClientAmountMonth();
                 }
                 po.clientId = vo.clientId ;
                 po.year = statisticsYear ;
-                po.month = statisticsMonth ;
-                po.amount = vo.amount;
-                po.money = vo.money ;
+                this.setValueOfMonthOfYear(statisticsMonth, vo, po) ;
                 if(po.id == null) {
                     stClientAmountMonthDao.insert(po);
                 }else{
@@ -67,20 +90,17 @@
     protected void statisticsYear(Integer statisticsYear){
         List<VoClientAmountStatistics> list = stClientAmountMonthDao.statisticsByClient(statisticsYear) ;
         if(list != null && list.size() > 0){
+            List<StClientAmountYear> listOfYear = stClientAmountYearDao.selectByYear(statisticsYear) ;
             for(VoClientAmountStatistics vo : list){
-                List<StClientAmountYear> listOfYear = stClientAmountYearDao.selectByClientIdAndYear(vo.clientId, statisticsYear) ;
-                StClientAmountYear po = null ;
-                if(listOfYear != null && listOfYear.size() > 0){
-                    //绋嬪簭閫昏緫鎺у埗涓婏紝闆嗗悎涓彧鏈変竴涓璞�
-                    po = listOfYear.get(0) ;
-                }
+                StClientAmountYear po = this.getYearDataOfClient(listOfYear, vo.clientId) ;
                 if(po == null) {
                     po = new StClientAmountYear();
                 }
                 po.clientId = vo.clientId ;
                 po.year = statisticsYear ;
-                po.amount = vo.amount;
+                po.amount = vo.amount ;
                 po.money = vo.money ;
+                po.times = vo.times ;
                 if(po.id == null) {
                     stClientAmountYearDao.insert(po);
                 }else{
@@ -89,4 +109,270 @@
             }
         }
     }
+
+
+    private StClientAmountDay getDayDataOfClient(List<StClientAmountDay> list, Long clientId){
+        if(list != null && list.size() > 0){
+            for(StClientAmountDay po : list){
+                if(po.clientId.longValue() == clientId.longValue()){
+                    //绋嬪簭閫昏緫鎺у埗涓婏紝闆嗗悎涓彧鏈変竴涓璞�
+                    return po;
+                }
+            }
+        }
+        return null ;
+    }
+
+
+    private StClientAmountMonth getMonthDataOfClient(List<StClientAmountMonth> list, Long clientId){
+        if(list != null && list.size() > 0){
+            for(StClientAmountMonth po : list){
+                if(po.clientId.longValue() == clientId.longValue()){
+                    //绋嬪簭閫昏緫鎺у埗涓婏紝闆嗗悎涓彧鏈変竴涓璞�
+                    return po;
+                }
+            }
+        }
+        return null ;
+    }
+
+
+    private StClientAmountYear getYearDataOfClient(List<StClientAmountYear> list, Long clientId){
+        if(list != null && list.size() > 0){
+            for(StClientAmountYear po : list){
+                if(po.clientId.longValue() == clientId.longValue()){
+                    //绋嬪簭閫昏緫鎺у埗涓婏紝闆嗗悎涓彧鏈変竴涓璞�
+                    return po;
+                }
+            }
+        }
+        return null ;
+    }
+
+
+    private void setValueOfDayOfMonth(Integer statisticsDay, VoClientAmountStatistics vo, StClientAmountDay po){
+        switch (statisticsDay) {
+            case 1:
+                po.amount1 = vo.amount;
+                po.money1 = vo.money;
+                po.times1 = vo.times;
+                break;
+            case 2:
+                po.amount2 = vo.amount;
+                po.money2 = vo.money;
+                po.times2 = vo.times;
+                break;
+            case 3:
+                po.amount3 = vo.amount;
+                po.money3 = vo.money;
+                po.times3 = vo.times;
+                break;
+            case 4:
+                po.amount4 = vo.amount;
+                po.money4 = vo.money;
+                po.times4 = vo.times;
+                break;
+            case 5:
+                po.amount5 = vo.amount;
+                po.money5 = vo.money;
+                po.times5 = vo.times;
+                break;
+            case 6:
+                po.amount6 = vo.amount;
+                po.money6 = vo.money;
+                po.times6 = vo.times;
+                break;
+            case 7:
+                po.amount7 = vo.amount;
+                po.money7 = vo.money;
+                po.times7 = vo.times;
+                break;
+            case 8:
+                po.amount8 = vo.amount;
+                po.money8 = vo.money;
+                po.times8 = vo.times;
+                break;
+            case 9:
+                po.amount9 = vo.amount;
+                po.money9 = vo.money;
+                po.times9 = vo.times;
+                break;
+            case 10:
+                po.amount10 = vo.amount;
+                po.money10 = vo.money;
+                po.times10 = vo.times;
+                break;
+            case 11:
+                po.amount11 = vo.amount;
+                po.money11 = vo.money;
+                po.times11 = vo.times;
+                break;
+            case 12:
+                po.amount12 = vo.amount;
+                po.money12 = vo.money;
+                po.times12 = vo.times;
+                break;
+            case 13:
+                po.amount13 = vo.amount;
+                po.money13 = vo.money;
+                po.times13 = vo.times;
+                break;
+            case 14:
+                po.amount14 = vo.amount;
+                po.money14 = vo.money;
+                po.times14 = vo.times;
+                break;
+            case 15:
+                po.amount15 = vo.amount;
+                po.money15 = vo.money;
+                po.times15 = vo.times;
+                break;
+            case 16:
+                po.amount16 = vo.amount;
+                po.money16 = vo.money;
+                po.times16 = vo.times;
+                break;
+            case 17:
+                po.amount17 = vo.amount;
+                po.money17 = vo.money;
+                po.times17 = vo.times;
+                break;
+            case 18:
+                po.amount18 = vo.amount;
+                po.money18 = vo.money;
+                po.times18 = vo.times;
+                break;
+            case 19:
+                po.amount19 = vo.amount;
+                po.money19 = vo.money;
+                po.times19 = vo.times;
+                break;
+            case 20:
+                po.amount20 = vo.amount;
+                po.money20 = vo.money;
+                po.times20 = vo.times;
+                break;
+            case 21:
+                po.amount21 = vo.amount;
+                po.money21 = vo.money;
+                po.times21 = vo.times;
+                break;
+            case 22:
+                po.amount22 = vo.amount;
+                po.money22 = vo.money;
+                po.times22 = vo.times;
+                break;
+            case 23:
+                po.amount23 = vo.amount;
+                po.money23 = vo.money;
+                po.times23 = vo.times;
+                break;
+            case 24:
+                po.amount24 = vo.amount;
+                po.money24 = vo.money;
+                po.times24 = vo.times;
+                break;
+            case 25:
+                po.amount25 = vo.amount;
+                po.money25 = vo.money;
+                po.times25 = vo.times;
+                break;
+            case 26:
+                po.amount26 = vo.amount;
+                po.money26 = vo.money;
+                po.times26 = vo.times;
+                break;
+            case 27:
+                po.amount27 = vo.amount;
+                po.money27 = vo.money;
+                po.times27 = vo.times;
+                break;
+            case 28:
+                po.amount28 = vo.amount;
+                po.money28 = vo.money;
+                po.times28 = vo.times;
+                break;
+            case 29:
+                po.amount29 = vo.amount;
+                po.money29 = vo.money;
+                po.times29 = vo.times;
+                break;
+            case 30:
+                po.amount30 = vo.amount;
+                po.money30 = vo.money;
+                po.times30 = vo.times;
+                break;
+            case 31:
+                po.amount31 = vo.amount;
+                po.money31 = vo.money;
+                po.times31 = vo.times;
+                break;
+        }
+    }
+
+    private void setValueOfMonthOfYear(Integer statisticsMonth, VoClientAmountStatistics vo, StClientAmountMonth po){
+        switch (statisticsMonth) {
+            case 1:
+                po.amount1 = vo.amount;
+                po.money1 = vo.money;
+                po.times1 = vo.times;
+                break;
+            case 2:
+                po.amount2 = vo.amount;
+                po.money2 = vo.money;
+                po.times2 = vo.times;
+                break;
+            case 3:
+                po.amount3 = vo.amount;
+                po.money3 = vo.money;
+                po.times3 = vo.times;
+                break;
+            case 4:
+                po.amount4 = vo.amount;
+                po.money4 = vo.money;
+                po.times4 = vo.times;
+                break;
+            case 5:
+                po.amount5 = vo.amount;
+                po.money5 = vo.money;
+                po.times5 = vo.times;
+                break;
+            case 6:
+                po.amount6 = vo.amount;
+                po.money6 = vo.money;
+                po.times6 = vo.times;
+                break;
+            case 7:
+                po.amount7 = vo.amount;
+                po.money7 = vo.money;
+                po.times7 = vo.times;
+                break;
+            case 8:
+                po.amount8 = vo.amount;
+                po.money8 = vo.money;
+                po.times8 = vo.times;
+                break;
+            case 9:
+                po.amount9 = vo.amount;
+                po.money9 = vo.money;
+                po.times9 = vo.times;
+                break;
+            case 10:
+                po.amount10 = vo.amount;
+                po.money10 = vo.money;
+                po.times10 = vo.times;
+                break;
+            case 11:
+                po.amount11 = vo.amount;
+                po.money11 = vo.money;
+                po.times11 = vo.times;
+                break;
+            case 12:
+                po.amount12 = vo.amount;
+                po.money12 = vo.money;
+                po.times12 = vo.times;
+                break;
+        }
+    }
+
 }
--
Gitblit v1.8.0