EnvWaterServiceImpl.java 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package com.huimv.admin.service.impl;
  2. import cn.hutool.core.date.DateUtil;
  3. import cn.hutool.core.util.ObjectUtil;
  4. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  5. import com.huimv.admin.common.utils.DataUill;
  6. import com.huimv.admin.common.utils.Result;
  7. import com.huimv.admin.common.utils.ResultCode;
  8. import com.huimv.admin.entity.EnvWater;
  9. import com.huimv.admin.entity.vo.energyMonthVo;
  10. import com.huimv.admin.entity.vo.energyYearVo;
  11. import com.huimv.admin.mapper.EnvWaterMapper;
  12. import com.huimv.admin.service.IEnvWaterService;
  13. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  14. import org.springframework.beans.factory.annotation.Autowired;
  15. import org.springframework.stereotype.Service;
  16. import java.math.BigDecimal;
  17. import java.math.RoundingMode;
  18. import java.text.SimpleDateFormat;
  19. import java.util.*;
  20. /**
  21. * <p>
  22. * 服务实现类
  23. * </p>
  24. *
  25. * @author author
  26. * @since 2023-03-23
  27. */
  28. @Service
  29. public class EnvWaterServiceImpl extends ServiceImpl<EnvWaterMapper, EnvWater> implements IEnvWaterService {
  30. @Autowired
  31. private EnvWaterMapper envWaterMapper;
  32. @Override
  33. public Result listWater(Map<String, String> paramsMap) {
  34. Date timesMonthmorning = DataUill.getTimesMonthmorning();
  35. Date currentYearStartTime = DataUill.getCurrentYearStartTime();
  36. Date lastYearStartTime = DataUill.getLastYearStartTime();
  37. Date lastYearEndTime = DataUill.getLastYearEndTime();
  38. String farmId = paramsMap.get("farmId");
  39. String type = paramsMap.get("type");
  40. SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //格式化时间
  41. QueryWrapper<EnvWater> queryWrapper = new QueryWrapper<>();
  42. queryWrapper.eq("farm_id",farmId);
  43. Map resultMap = new HashMap();
  44. //月
  45. if ("1".equals(type)){
  46. queryWrapper.ge("update_time",timesMonthmorning);
  47. List<energyMonthVo> energyMonthVos = envWaterMapper.listDayWater(queryWrapper);
  48. resultMap.put("data", energyMonthVos);
  49. BigDecimal currentWater = envWaterMapper.getWater(queryWrapper);
  50. if (ObjectUtil.isNull(currentWater)){
  51. currentWater = BigDecimal.ZERO;
  52. }
  53. resultMap.put("currentValue",currentWater);
  54. //上个月
  55. //获取上个月的第一天
  56. Calendar cal_1 = Calendar.getInstance();//获取当前日期
  57. cal_1.add(Calendar.MONTH, -1);
  58. cal_1.set(Calendar.DAY_OF_MONTH, 1);//设置为1号
  59. cal_1.set(Calendar.HOUR_OF_DAY, 0);
  60. cal_1.set(Calendar.MINUTE, 0);
  61. cal_1.set(Calendar.SECOND, 0);
  62. String firstDay = format.format(cal_1.getTime());
  63. //获取上个月的最后一天
  64. Calendar cal_2 = Calendar.getInstance();
  65. cal_2.set(Calendar.DAY_OF_MONTH, 0);//设置为1号,当前日期既为本月第一天
  66. cal_2.set(Calendar.HOUR_OF_DAY, 23);
  67. cal_2.set(Calendar.MINUTE, 59);
  68. cal_2.set(Calendar.SECOND, 59);
  69. String lastDay = format.format(cal_2.getTime());
  70. QueryWrapper<EnvWater> wrapper = new QueryWrapper();
  71. wrapper.eq("farm_id",farmId).between("update_time",firstDay,lastDay);
  72. BigDecimal lastWater = envWaterMapper.getWater(wrapper);
  73. if (ObjectUtil.isNull(lastWater)){
  74. resultMap.put("lastValue",0);
  75. resultMap.put("gap",100);
  76. return new Result(ResultCode.SUCCESS,resultMap);
  77. }
  78. resultMap.put("lastValue",lastWater);
  79. double gap = ((currentWater.doubleValue() - lastWater.doubleValue()) / lastWater.doubleValue()) * 100;
  80. if (ObjectUtil.isNull(gap)){
  81. gap = 0.0;
  82. }
  83. if (Double.isInfinite(gap) || Double.isNaN(gap)) {
  84. gap = 0.0;
  85. }
  86. BigDecimal bg = new BigDecimal(gap).setScale(2, RoundingMode.UP);
  87. resultMap.put("gap",bg);
  88. return new Result(ResultCode.SUCCESS,resultMap);
  89. }else {
  90. //年
  91. queryWrapper.ge("update_time",currentYearStartTime);
  92. List<energyYearVo> energyMonthVos = envWaterMapper.listMonthWater(queryWrapper);
  93. resultMap.put("data", energyMonthVos);
  94. BigDecimal currentWater = envWaterMapper.getWater(queryWrapper);
  95. if (ObjectUtil.isNull(currentWater)){
  96. currentWater = BigDecimal.ZERO;
  97. }
  98. resultMap.put("currentValue",currentWater);
  99. //上一年
  100. String firstDay = format.format(lastYearStartTime);
  101. String lastDay = format.format(lastYearEndTime);
  102. QueryWrapper<EnvWater> wrapper = new QueryWrapper();
  103. wrapper.eq("farm_id",farmId).between("update_time",firstDay,lastDay);
  104. BigDecimal lastWater = envWaterMapper.getWater(wrapper);
  105. if (ObjectUtil.isNull(lastWater)){
  106. resultMap.put("lastValue",0);
  107. resultMap.put("gap",100);
  108. return new Result(ResultCode.SUCCESS,resultMap);
  109. }
  110. resultMap.put("lastValue",lastWater);
  111. double gap = ((currentWater.doubleValue() - lastWater.doubleValue()) / lastWater.doubleValue()) * 100;
  112. if (ObjectUtil.isNull(gap)){
  113. gap = 0.0;
  114. }
  115. BigDecimal bg = new BigDecimal(gap).setScale(2, RoundingMode.UP);
  116. resultMap.put("gap",bg);
  117. return new Result(ResultCode.SUCCESS,resultMap);
  118. }
  119. }
  120. @Override
  121. public String sumDayWater() {
  122. QueryWrapper<EnvWater> wrapper = new QueryWrapper<>();
  123. wrapper.eq("farm_Id", 27).ge("update_time", DateUtil.beginOfDay(new Date()));
  124. return envWaterMapper.sumDayWater(wrapper);
  125. }
  126. }