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.pojoSt.StConsumeClientMonth; import com.dy.pipIrrGlobal.pojoSt.StConsumeClientYear; import com.dy.pipIrrGlobal.voSt.VoClientAmountStatistics; import com.dy.pipIrrGlobal.voSt.VoClientConsumeStatistics; 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 StClientAmountSv { protected RmClientAmountDayMapper rmClientAmountDayDao; protected StClientAmountDayMapper stClientAmountDayDao; @Autowired private void setDao(RmClientAmountDayMapper dao) { this.rmClientAmountDayDao = dao; } @Autowired private void setDao(StClientAmountDayMapper dao) { this.stClientAmountDayDao = dao; } private static final int[][] yearMonthGrp = {{2024, 9}, {2024, 10}, {2024, 11}, {2024, 12}, {2025, 1}, {2025, 2}, {2025, 3}, {2025, 4}}; /** * 删除所有 * @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 : 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.statisticsDay(ym[0], ym[1], day, statistics4DayStartId, statistics4DayEndId); } } } } @Transactional protected void statisticsDay(Integer statisticsYear, Integer statisticsMonth, Integer statisticsDay, Long statisticsStartId, Long statisticsEndId){ List list = rmClientAmountDayDao.statisticsByClient(statisticsStartId, statisticsEndId) ; if(list != null && list.size() > 0){ for(VoClientAmountStatistics vo : list){ List listOfDay = stClientAmountDayDao.selectByClientIdAndYearAndMonthAndDay(vo.clientId, statisticsYear, statisticsMonth) ; StClientAmountDay po = null ; if(listOfDay != null && listOfDay.size() > 0){ //程序逻辑控制上,集合中只有一个对象 po = listOfDay.get(0) ; } 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) ; } } } } 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, VoClientConsumeStatistics vo, StConsumeClientMonth po){ switch (statisticsMonth) { case 1: po.amount1 = vo.amount; po.times1 = vo.times; break; case 2: po.amount2 = vo.amount; po.times2 = vo.times; break; case 3: po.amount3 = vo.amount; po.times3 = vo.times; break; case 4: po.amount4 = vo.amount; po.times4 = vo.times; break; case 5: po.amount5 = vo.amount; po.times5 = vo.times; break; case 6: po.amount6 = vo.amount; po.times6 = vo.times; break; case 7: po.amount7 = vo.amount; po.times7 = vo.times; break; case 8: po.amount8 = vo.amount; po.times8 = vo.times; break; case 9: po.amount9 = vo.amount; po.times9 = vo.times; break; case 10: po.amount10 = vo.amount; po.times10 = vo.times; break; case 11: po.amount11 = vo.amount; po.times11 = vo.times; break; case 12: po.amount12 = vo.amount; po.times12 = vo.times; break; } } private void setValueOfYear(VoClientConsumeStatistics vo, StConsumeClientYear po){ po.amount = vo.amount; po.times = vo.times; } }