From 25576c047e39101a4784d8acffc92af3f35aa215 Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Tue, 29 Nov 2022 16:34:32 +0800
Subject: [PATCH] 解决国控站数据补偿问题

---
 screen-manage/src/main/java/com/moral/api/service/impl/HistoryMinutelyServiceImpl.java |    2 +-
 screen-manage/src/main/java/com/moral/api/service/DeviceService.java                   |    2 +-
 screen-manage/src/main/resources/mapper/HistoryHourlyMapper.xml                        |    8 ++++++++
 screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java          |   27 ++++++++++++++++++++++++++-
 screen-manage/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java   |    2 +-
 screen-manage/src/main/java/com/moral/api/mapper/HistoryHourlyMapper.java              |    3 +++
 screen-manage/src/main/java/com/moral/api/kafka/consumer/DeviceConsumer.java           |    2 +-
 7 files changed, 41 insertions(+), 5 deletions(-)

diff --git a/screen-manage/src/main/java/com/moral/api/kafka/consumer/DeviceConsumer.java b/screen-manage/src/main/java/com/moral/api/kafka/consumer/DeviceConsumer.java
index 4c0f4a6..a00b64c 100644
--- a/screen-manage/src/main/java/com/moral/api/kafka/consumer/DeviceConsumer.java
+++ b/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);
diff --git a/screen-manage/src/main/java/com/moral/api/mapper/HistoryHourlyMapper.java b/screen-manage/src/main/java/com/moral/api/mapper/HistoryHourlyMapper.java
index b81df44..b2d3cc1 100644
--- a/screen-manage/src/main/java/com/moral/api/mapper/HistoryHourlyMapper.java
+++ b/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);
+
 }
diff --git a/screen-manage/src/main/java/com/moral/api/service/DeviceService.java b/screen-manage/src/main/java/com/moral/api/service/DeviceService.java
index e8fd83c..899c7ae 100644
--- a/screen-manage/src/main/java/com/moral/api/service/DeviceService.java
+++ b/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);
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java
index 89e6b95..727f821 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java
+++ b/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");
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java
index fb293a2..a0944c6 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java
+++ b/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);
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/HistoryMinutelyServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/HistoryMinutelyServiceImpl.java
index 5fac9b4..586d8bf 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/HistoryMinutelyServiceImpl.java
+++ b/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);
diff --git a/screen-manage/src/main/resources/mapper/HistoryHourlyMapper.xml b/screen-manage/src/main/resources/mapper/HistoryHourlyMapper.xml
index 701b196..641794c 100644
--- a/screen-manage/src/main/resources/mapper/HistoryHourlyMapper.xml
+++ b/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>
\ No newline at end of file

--
Gitblit v1.8.0