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;
|
}
|
}
|
|
}
|