screen-manage/src/main/java/com/moral/api/kafka/consumer/DeviceConsumer.java
@@ -138,7 +138,7 @@ data.remove("entryTime"); //数据校准 data = deviceService.adjustDeviceData(data); data = deviceService.adjustDeviceData(data,"0"); //存入redis data.put("DataTime", time); redisTemplate.opsForHash().put(RedisConstants.DATA_SECOND, mac, data); screen-manage/src/main/java/com/moral/api/mapper/HistoryHourlyMapper.java
@@ -14,4 +14,7 @@ void insertHistoryHourly(Map<String, Object> params); Map<String,Object> selectHistoryHourly(Map<String, Object> params); } screen-manage/src/main/java/com/moral/api/service/DeviceService.java
@@ -56,7 +56,7 @@ Map<String, Object> getDeviceByMac(String mac); //设备数据校准 Map<String, Object> adjustDeviceData(Map<String, Object> deviceData); Map<String, Object> adjustDeviceData(Map<String, Object> deviceData,String code); //特殊设备数据校准 Map<String, Object> adjustSpecialDeviceData(Map<String, Object> deviceData); screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java
@@ -22,6 +22,7 @@ import com.moral.constant.RedisConstants; import com.moral.util.ConvertUtils; import com.moral.util.DateUtils; import com.sun.javafx.collections.MappingChange; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; @@ -36,6 +37,8 @@ import java.beans.PropertyDescriptor; import java.lang.reflect.Field; import java.lang.reflect.Method; import java.lang.reflect.Type; import java.text.SimpleDateFormat; import java.util.*; import java.util.stream.Collectors; @@ -441,8 +444,10 @@ return deviceInfo; } @Autowired private HistoryHourlyMapper historyHourlyMapper; @Override public Map<String, Object> adjustDeviceData(Map<String, Object> deviceData) { public Map<String, Object> adjustDeviceData(Map<String, Object> deviceData,String code) { String mac = deviceData.remove("mac").toString(); //从redis获取校准公式 Map<String, Object> adjustFormula = redisTemplate.opsForHash().entries(RedisConstants.ADJUST + "_" + mac); @@ -454,6 +459,26 @@ if (govMpInfo.get("guid") != null) { aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, govMpInfo.get("guid").toString()); } if (code.equals("2")){ if (ObjectUtils.isEmpty(aqiMap.get("a21005")) || ObjectUtils.isEmpty(aqiMap.get("a21026")) || ObjectUtils.isEmpty(aqiMap.get("a21004")) || ObjectUtils.isEmpty(aqiMap.get("a34002")) || ObjectUtils.isEmpty(aqiMap.get("a34004")) || ObjectUtils.isEmpty(aqiMap.get("a05024")) || ObjectUtils.isEmpty(aqiMap)){ HashMap<String, Object> result = new HashMap<>(); String dataTime = deviceData.get("DataTime").toString(); Date time = DateUtils.getDate(dataTime, DateUtils.yyyyMMddHHmmss_EN); String yearAndMonth = DateUtils.dateToDateString(DateUtils.addHours(time, -1), DateUtils.yyyyMM_EN); SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:00:00"); String format = simpleDateFormat.format(DateUtils.addHours(time, -1)); result.put("timeUnits",yearAndMonth); result.put("mac",mac); result.put("time",format); Map<String, Object> map = historyHourlyMapper.selectHistoryHourly(result); if (!ObjectUtils.isEmpty(map)){ return JSON.parseObject(map.get("value").toString(), Map.class); } } } return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap); } deviceData.remove("DataTime"); screen-manage/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java
@@ -62,7 +62,7 @@ historyHourlyMapper.insertHistoryHourly(result); //数据校准 dataAdjust = deviceService.adjustDeviceData(dataAdjust); dataAdjust = deviceService.adjustDeviceData(dataAdjust,"2"); //校准后小时表insert result.put("timeUnits", yearAndMonth); screen-manage/src/main/java/com/moral/api/service/impl/HistoryMinutelyServiceImpl.java
@@ -53,7 +53,7 @@ historyMinutelyMapper.insertHistoryMinutely(result); //数据校准 dataAdjust = deviceService.adjustDeviceData(dataAdjust); dataAdjust = deviceService.adjustDeviceData(dataAdjust,"1"); result.put("timeUnits", timeUnits); result.put("value", JSONObject.toJSONString(dataAdjust)); historyMinutelyMapper.insertHistoryMinutely(result); screen-manage/src/main/resources/mapper/HistoryHourlyMapper.xml
@@ -7,4 +7,12 @@ VALUES (#{mac}, #{time}, #{value}, #{version}) </insert> <select id="selectHistoryHourly" resultType="java.util.Map"> SELECT `value` FROM history_hourly_${timeUnits} WHERE `time` = #{time} and mac = #{mac} </select> </mapper>