| package com.dy.pipIrrTemp.statistics; | 
|   | 
| import com.dy.common.util.DateTime; | 
| import com.dy.common.util.IDLongGenerator; | 
| import com.dy.pipIrrGlobal.daoRm.RmClientAmountDayMapper; | 
| import com.dy.pipIrrGlobal.daoSt.StClientAmountDayMapper; | 
| import com.dy.pipIrrGlobal.pojoSt.StClientAmountDay; | 
| import com.dy.pipIrrGlobal.voSt.VoClientAmountStatistics; | 
| import com.dy.pipIrrTemp.util.StClientAmountConstant; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.transaction.annotation.Transactional; | 
|   | 
| import java.util.List; | 
|   | 
| /** | 
|  * @Author: liurunyu | 
|  * @Date: 2024/12/28 12:52 | 
|  * @Description | 
|  */ | 
|   | 
| @Slf4j | 
| @Service | 
| public class StClientAmountDaySv { | 
|   | 
|     protected RmClientAmountDayMapper rmClientAmountDayDao; | 
|   | 
|     protected StClientAmountDayMapper stClientAmountDayDao; | 
|   | 
|     @Autowired | 
|     private void setDao(RmClientAmountDayMapper dao) { | 
|         this.rmClientAmountDayDao = dao; | 
|     } | 
|   | 
|     @Autowired | 
|     private void setDao(StClientAmountDayMapper dao) { | 
|         this.stClientAmountDayDao = dao; | 
|     } | 
|   | 
|     /** | 
|      * 删除所有 | 
|      * @throws Exception | 
|      */ | 
|     public void deleteAllStClientAmountDay() throws Exception { | 
|         stClientAmountDayDao.deleteAll() ; | 
|     } | 
|   | 
|     /** | 
|      * 转存农户日取水量,由纵型改为横型 | 
|      * | 
|      * @throws Exception | 
|      */ | 
|     public void transSaveClientAmountDay() throws Exception { | 
|         //统计到昨天,今天的统计明日零晨定时任务统计 | 
|         Long yesterday = Long.parseLong(DateTime.lastXDay_yyyy_MM_dd(1).replaceAll("-", "")); | 
|         Long atDay = Long.MAX_VALUE ; | 
|         int endDayOfMonth = 0 ; | 
|         for(int[] ym : StClientAmountConstant.yearMonthGrp) { | 
|             endDayOfMonth = DateTime.endDayOfMonth(ym[0], ym[1]) ; | 
|             for (int day = 1; day <= endDayOfMonth; day++) { | 
|                 atDay = Long.parseLong(ym[0] + "" + (ym[1] < 10?("0" + ym[1]):ym[1]) + "" + (day < 10?("0" + day):day)) ; | 
|                 if(atDay <= yesterday) { | 
|                     Long statistics4DayStartId = IDLongGenerator.generateOneDayStartId(ym[0], ym[1], day); | 
|                     Long statistics4DayEndId = IDLongGenerator.generateOneDayEndId(ym[0], ym[1], day); | 
|                     this.doSome(ym[0], ym[1], day, statistics4DayStartId, statistics4DayEndId); | 
|                 } | 
|             } | 
|         } | 
|      } | 
|   | 
|   | 
|     @Transactional | 
|     protected void doSome(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.getDataOfClient(listOfDay, vo.clientId) ; | 
|                 if(po == null){ | 
|                     po = new StClientAmountDay() ; | 
|                     po.clientId = vo.clientId ; | 
|                     po.year = statisticsYear ; | 
|                     po.month = statisticsMonth ; | 
|                 } | 
|                 this.setValue(statisticsDay, vo, po); | 
|                 if(po.id == null) { | 
|                     stClientAmountDayDao.insert(po); | 
|                 }else{ | 
|                     stClientAmountDayDao.updateByPrimaryKeySelective(po) ; | 
|                 } | 
|             } | 
|         } | 
|     } | 
|   | 
|   | 
|     private StClientAmountDay getDataOfClient(List<StClientAmountDay> list, Long clientId){ | 
|         if(list != null && list.size() > 0){ | 
|             for(StClientAmountDay vo : list){ | 
|                 if(vo.clientId.longValue() == clientId.longValue()){ | 
|                     //程序逻辑控制上,集合中只有一个对象 | 
|                     return vo ; | 
|                 } | 
|             } | 
|         } | 
|         return null ; | 
|     } | 
|   | 
|     private void setValue(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; | 
|         } | 
|     } | 
|   | 
| } |