EnergyElectricityServiceImpl.java 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. package com.huimv.admin.service.impl;
  2. import cn.hutool.core.date.DateTime;
  3. import cn.hutool.core.date.DateUtil;
  4. import cn.hutool.core.util.ObjectUtil;
  5. import com.alibaba.fastjson.JSONArray;
  6. import com.alibaba.fastjson.JSONObject;
  7. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  8. import com.huimv.admin.common.utils.DataUill;
  9. import com.huimv.admin.common.utils.Result;
  10. import com.huimv.admin.common.utils.ResultCode;
  11. import com.huimv.admin.entity.BasePigpen;
  12. import com.huimv.admin.entity.EnergyData;
  13. import com.huimv.admin.entity.EnergyElectricity;
  14. import com.huimv.admin.entity.vo.EnergyElectricityDataVo;
  15. import com.huimv.admin.mapper.BasePigpenMapper;
  16. import com.huimv.admin.mapper.EnergyDataMapper;
  17. import com.huimv.admin.mapper.EnergyElectricityMapper;
  18. import com.huimv.admin.service.IEnergyElectricityService;
  19. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  20. import org.springframework.beans.factory.annotation.Autowired;
  21. import org.springframework.stereotype.Service;
  22. import javax.servlet.http.HttpServletRequest;
  23. import java.util.Calendar;
  24. import java.util.Date;
  25. import java.util.List;
  26. import java.util.Map;
  27. /**
  28. * <p>
  29. * 服务实现类
  30. * </p>
  31. *
  32. * @author author
  33. * @since 2023-02-14
  34. */
  35. @Service
  36. public class EnergyElectricityServiceImpl extends ServiceImpl<EnergyElectricityMapper, EnergyElectricity> implements IEnergyElectricityService {
  37. @Autowired
  38. private EnergyElectricityMapper energyElectricityMapper;
  39. @Autowired
  40. private BasePigpenMapper basePigpenMapper;
  41. @Autowired
  42. private EnergyDataMapper dataMapper;
  43. @Override
  44. public Result listPigpen(HttpServletRequest httpServletRequest, Map<String, String> paramsMap) {
  45. String farmId = paramsMap.get("farmId");
  46. String id = paramsMap.get("id");//层id
  47. JSONArray jsonArray = new JSONArray();
  48. QueryWrapper<BasePigpen> basePigpenQueryWrapper = new QueryWrapper<>();
  49. if (id == null || id == "") {
  50. basePigpenQueryWrapper.eq("farm_id", farmId).eq("parent_id", 0);
  51. List<BasePigpen> basePigpens = basePigpenMapper.selectList(basePigpenQueryWrapper);//所有栋
  52. for (BasePigpen pigpen : basePigpens) {
  53. QueryWrapper<BasePigpen> queryWrapper = new QueryWrapper<>();
  54. queryWrapper.eq("farm_id", farmId).like("other2", pigpen.getId());
  55. List<BasePigpen> basePigpens1 = basePigpenMapper.selectList(queryWrapper);//所有层
  56. for (BasePigpen basePigpen : basePigpens1) {
  57. QueryWrapper<BasePigpen> queryWrapper1 = new QueryWrapper<>();
  58. queryWrapper1.eq("farm_id", farmId).like("other2", basePigpen.getId());//所有单元
  59. List<BasePigpen> basePigpens2 = basePigpenMapper.selectList(queryWrapper1);
  60. for (BasePigpen basePigpen1 : basePigpens2) {
  61. JSONObject jsonObject = new JSONObject();
  62. QueryWrapper<EnergyData> energyElectricityQueryWrapper = new QueryWrapper<>();
  63. energyElectricityQueryWrapper.eq("farm_id", farmId).eq("unit_id", basePigpen1.getId())
  64. .orderByDesc("create_date").last(" limit 1");
  65. EnergyData energyElectricity = dataMapper.selectOne(energyElectricityQueryWrapper);
  66. if (ObjectUtil.isEmpty(energyElectricity)) {
  67. jsonObject.put("buildName", basePigpen1.getBuildName());
  68. jsonObject.put("value", 0);
  69. jsonObject.put("id", basePigpen1.getId());
  70. } else {
  71. jsonObject.put("buildName", basePigpen1.getBuildName());
  72. jsonObject.put("value", energyElectricity.getElectricityValue());
  73. jsonObject.put("id", basePigpen1.getId());
  74. }
  75. jsonArray.add(jsonObject);
  76. }
  77. }
  78. }
  79. } else {
  80. basePigpenQueryWrapper.eq("farm_id", farmId).like("other2", id);
  81. List<BasePigpen> basePigpens = basePigpenMapper.selectList(basePigpenQueryWrapper);//所有的单元
  82. for (BasePigpen basePigpen : basePigpens) {
  83. JSONObject jsonObject = new JSONObject();
  84. QueryWrapper<EnergyData> queryWrapper = new QueryWrapper<>();
  85. queryWrapper.eq("farm_id", farmId).eq("unit_id", basePigpen.getId())
  86. .orderByDesc("create_date").last(" limit 1");
  87. EnergyData energyElectricity = dataMapper.selectOne(queryWrapper);
  88. if (ObjectUtil.isEmpty(energyElectricity)) {
  89. jsonObject.put("buildName", basePigpen.getBuildName());
  90. jsonObject.put("value", 0);
  91. jsonObject.put("id", basePigpen.getId());
  92. } else {
  93. jsonObject.put("buildName", basePigpen.getBuildName());
  94. jsonObject.put("value", energyElectricity.getElectricityValue());
  95. jsonObject.put("id", basePigpen.getId());
  96. }
  97. jsonArray.add(jsonObject);
  98. }
  99. }
  100. return new Result(ResultCode.SUCCESS,jsonArray);
  101. }
  102. @Override
  103. public Result listData(HttpServletRequest httpServletRequest, Map<String, String> paramsMap) {
  104. String farmId = paramsMap.get("farmId");
  105. String type = paramsMap.get("type");
  106. String id = paramsMap.get("id");
  107. String startTime = paramsMap.get("startTime");
  108. String endTime = paramsMap.get("endTime");
  109. if (type == null || type == "") {
  110. type = "3";
  111. }
  112. QueryWrapper<EnergyData> queryWrapper = new QueryWrapper<>();
  113. queryWrapper.eq("farm_id", farmId).eq("unit_id", id);
  114. List<EnergyElectricityDataVo> electricityList = null;
  115. //自定义查询
  116. if ("4".equals(type)) {
  117. startTime = startTime + " 00:00:00";
  118. endTime = endTime + " 23:59:59";
  119. queryWrapper.between("create_date", startTime, endTime);
  120. electricityList = dataMapper.listDay4(queryWrapper);
  121. }
  122. //本年
  123. else if ("3".equals(type)) {
  124. DateTime dateTime = DateUtil.beginOfYear(new Date());
  125. queryWrapper.ge("create_date", dateTime);
  126. List<EnergyElectricityDataVo> energyElectricityDataVos = dataMapper.listYear4(queryWrapper);
  127. for (EnergyElectricityDataVo energyElectricityDataVo : energyElectricityDataVos) {
  128. if (energyElectricityDataVo.getElectricityValue() == null || energyElectricityDataVo.getElectricityValue() == "") {
  129. energyElectricityDataVo.setElectricityValue("0");
  130. }
  131. }
  132. electricityList = energyElectricityDataVos;
  133. }
  134. //本月
  135. else if ("2".equals(type)) {
  136. Date timesMonthmorning = DataUill.getTimesMonthmorning();
  137. queryWrapper.ge("create_date", timesMonthmorning);
  138. electricityList = dataMapper.listDay4(queryWrapper);
  139. }
  140. //本周
  141. else if ("1".equals(type)) {
  142. Calendar calendar = Calendar.getInstance();
  143. calendar.set(Calendar.DATE, calendar.get(Calendar.DATE) - 7);
  144. queryWrapper.ge("create_date", calendar.getTime());
  145. List<EnergyElectricityDataVo> energyElectricityDataVos = dataMapper.listDay4(queryWrapper);
  146. for (EnergyElectricityDataVo energyElectricityDataVo : energyElectricityDataVos) {
  147. if (energyElectricityDataVo.getElectricityValue() == null || energyElectricityDataVo.getElectricityValue() == "") {
  148. energyElectricityDataVo.setElectricityValue("0");
  149. }
  150. }
  151. electricityList = energyElectricityDataVos;
  152. }
  153. return new Result(ResultCode.SUCCESS, electricityList);
  154. }
  155. }