From 65007f6811e580d8660340b8216296e68fae598c Mon Sep 17 00:00:00 2001
From: kaiyu <404897439@qq.com>
Date: Tue, 01 Dec 2020 16:04:18 +0800
Subject: [PATCH] Merge branch 'master' of http://blit.7drlb.com:8888/r/screen_api_v2

---
 src/main/java/com/moral/service/impl/HistoryServiceImpl.java       |    6 
 src/main/java/com/moral/util/AQICalculation2.java                  |   75 ++++----
 src/main/resources/mapper/HistoryMapper.xml                        |   12 
 src/main/resources/mapper/HistoryHourlyMapper.xml                  |   18 +-
 src/main/java/com/moral/controller/ScreenController.java           |  207 ++++++++++++++++++++++++-
 src/main/java/com/moral/service/impl/HistoryHourlyServiceImpl.java |  106 +++++++++++-
 6 files changed, 351 insertions(+), 73 deletions(-)

diff --git a/src/main/java/com/moral/controller/ScreenController.java b/src/main/java/com/moral/controller/ScreenController.java
index cfe9a84..fb4e86b 100644
--- a/src/main/java/com/moral/controller/ScreenController.java
+++ b/src/main/java/com/moral/controller/ScreenController.java
@@ -2718,7 +2718,7 @@
     @ApiImplicitParams(value = {
             @ApiImplicitParam(name = "monitorPointIds", value = "������monitorid", required = true, paramType = "query", dataType = "String"),
             @ApiImplicitParam(name = "time", value = "������(���������2020-03-19)", required = true, paramType = "query", dataType = "String")})
-    public ResultBean<List<List<Map<String,Object>>>> monitorAVGData(HttpServletRequest request) throws Exception {
+    public ResultBean<List<Map<String,Object>>> monitorAVGData(HttpServletRequest request) throws Exception {
         Map<String, Object> parameters = getParametersStartingWith(request, null);
         String monitorPointIds = (String) parameters.get("monitorPointIds");
         String time = (String) parameters.get("time");
@@ -2739,10 +2739,20 @@
             Map<String,Object> dailyAvgData =new HashMap<>();
             if (dataAvbByMIdAndTime.get(dataAvbByMIdAndTime.size() - 2).get("data")!=""){
                 dailyAvgData = (Map<String, Object>) dataAvbByMIdAndTime.get(dataAvbByMIdAndTime.size() - 2).get("data");
-                dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+                dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
             }else {
                 dailyAvgData= historyHourlyService.getAvgDataByMId(mId, date1, date2);
-                dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+                if (dailyAvgData!=null){
+                    dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
+                }else {
+                    dailyAvgData = new HashMap<>();
+                    dailyAvgData.put("PM2_5","");
+                    dailyAvgData.put("NO2","");
+                    dailyAvgData.put("SO2","");
+                    dailyAvgData.put("PM10","");
+                    dailyAvgData.put("O3_day","");
+                    dailyAvgData.put("CO","");
+                }
             }
             dataAvbByMIdAndTime.remove(dataAvbByMIdAndTime.size() - 1);
             dataAvbByMIdAndTime.remove(dataAvbByMIdAndTime.size() - 1);
@@ -2753,7 +2763,7 @@
             for (int i = 0; i <dataAvbByMIdAndTime.size() ; i++) {
                 if (i!=dataAvbByMIdAndTime.size()-1){
                     Map<String, Object> map1 = AQICalculation2.hourlyAQI((Map<String, Object>) dataAvbByMIdAndTime.get(i).get("data"));
-                    if (Double.parseDouble(map1.get("AQI").toString())>=50.0){
+                    if (Double.parseDouble(map1.get("AQI").toString())>50.0){
                         ((Map<String, Object>) dataAvbByMIdAndTime.get(i).get("data")).put("primary_pollutants",map1.get("maxSensor"));
                         ((Map<String, Object>) dataAvbByMIdAndTime.get(i).get("data")).put("AQI",map1.get("AQI"));
                     }else {
@@ -2762,7 +2772,10 @@
                     }
                 }else {
                     Map<String, Object> map1 = AQICalculation2.dayAQI((Map<String, Object>) dataAvbByMIdAndTime.get(i).get("data"));
-                        if (Double.parseDouble(map1.get("AQI").toString())>=50.0){
+                    if (map1.get("AQI").toString().equals("")){
+                        break;
+                    }
+                        if (Double.parseDouble(map1.get("AQI").toString())>50.0){
                             ((Map<String, Object>) dataAvbByMIdAndTime.get(i).get("data")).put("primary_pollutants",map1.get("maxSensor"));
                             ((Map<String, Object>) dataAvbByMIdAndTime.get(i).get("data")).put("AQI",map1.get("AQI"));
                         }else {
@@ -2770,6 +2783,74 @@
                             ((Map<String, Object>) dataAvbByMIdAndTime.get(i).get("data")).put("AQI",map1.get("AQI"));
                         }
                 }
+            }
+            List timeList = new ArrayList();
+            for (int q = 0; q < dataAvbByMIdAndTime.size(); q++) {
+                timeList.add(dataAvbByMIdAndTime.get(q).get("time"));
+            }
+            if (dataAvbByMIdAndTime.size()<25){
+                for (int j = 1; j < 25; j++) {
+                    Map<String,Object> map = null;
+                    for (int q = 0; q < dataAvbByMIdAndTime.size(); q++) {
+                        if (dataAvbByMIdAndTime.get(q).get("time").toString().length() > 2){
+                            continue;
+                        }else {
+                            // System.out.println(Integer.parseInt(dataAvbByMIdAndTime.get(q).get("time").toString())+"==="+j);
+                            String sj="";
+                            if (j<10){
+                                sj="0"+j;
+                            }else {
+                                if (j==24){
+                                    sj="00";
+                                }else {
+                                    sj=""+j;
+                                }
+                            }
+                            if (!timeList.contains(sj)){
+                                map = new HashMap<>();
+                                map.put("time",sj);
+                                Map map1 = new HashMap();
+                                map1.put("PM2_5","");
+                                map1.put("NO2","");
+                                map1.put("primary_pollutants","-");
+                                map1.put("SO2","");
+                                map1.put("O3","");
+                                map1.put("PM10","");
+                                map1.put("O3_8h","");
+                                map1.put("CO","");
+                                map1.put("AQI","");
+                                map.put("data",map1);
+                                dataAvbByMIdAndTime.add(map);
+                                break;
+                            }else {
+                                break;
+                            }
+                        }
+                    }
+                }
+            }
+             /* for (int i1 = 0; i1 < dataAvbByMIdAndTime.size(); i1++) {
+                    System.out.println(dataAvbByMIdAndTime.get(i1));
+                }*/
+            Collections.sort(dataAvbByMIdAndTime, new Comparator<Map<String, Object>>(){
+                public int compare(Map<String, Object> o1, Map<String, Object> o2) {
+                    String name1 =(String)o1.get("time");//name1���������list������������������������
+                    String name2= (String)o2.get("time"); //name1���������list���������������������������name
+                    return name1.compareTo(name2);
+                }
+            });
+            Map map1 = dataAvbByMIdAndTime.get(0);
+            dataAvbByMIdAndTime.remove(0);
+            dataAvbByMIdAndTime.add(map1);
+            for (int j = 0; j <dataAvbByMIdAndTime.size() ; j++) {
+                if (dataAvbByMIdAndTime.get(j).get("time").toString().length()>2){
+                    Map map2 = dataAvbByMIdAndTime.get(j);
+                    dataAvbByMIdAndTime.remove(j);
+                    dataAvbByMIdAndTime.add(map2);
+                }
+            }
+            if (dataAvbByMIdAndTime.size()==1){
+                dataAvbByMIdAndTime=null;
             }
             lists.add(dataAvbByMIdAndTime);
             //List<Device> devicesByMonitorPointId = deviceService.getDevicesByMonitorPointId(Integer.valueOf(mId));
@@ -2780,10 +2861,20 @@
                 Map<String,Object> dailyAvgData =new HashMap<>();
                 if (dataAvbByMIdAndTime.get(dataAvbByMIdAndTime.size() - 2).get("data")!=""){
                     dailyAvgData = (Map<String, Object>) dataAvbByMIdAndTime.get(dataAvbByMIdAndTime.size() - 2).get("data");
-                    dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+                    dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
                 }else {
                     dailyAvgData= historyHourlyService.getAvgDataByMId(mIds[i], date1, date2);
-                    dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+                    if (dailyAvgData!=null){
+                        dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
+                    }else {
+                        dailyAvgData = new HashMap<>();
+                        dailyAvgData.put("PM2_5","");
+                        dailyAvgData.put("NO2","");
+                        dailyAvgData.put("SO2","");
+                        dailyAvgData.put("PM10","");
+                        dailyAvgData.put("O3_day","");
+                        dailyAvgData.put("CO","");
+                    }
                 }
                 dataAvbByMIdAndTime.remove(dataAvbByMIdAndTime.size() - 1);
                 dataAvbByMIdAndTime.remove(dataAvbByMIdAndTime.size() - 1);
@@ -2791,11 +2882,109 @@
                 dayMap.put("data",dailyAvgData);
                 dayMap.put("time",date1.substring(0,11));
                 dataAvbByMIdAndTime.add(dayMap);
+                List timeList = new ArrayList();
+                for (int q = 0; q < dataAvbByMIdAndTime.size(); q++) {
+                    timeList.add(dataAvbByMIdAndTime.get(q).get("time"));
+                }
+                  if (dataAvbByMIdAndTime.size()<25){
+                    for (int j = 1; j < 25; j++) {
+                        Map<String,Object> map = null;
+                        for (int q = 0; q < dataAvbByMIdAndTime.size(); q++) {
+                            if (dataAvbByMIdAndTime.get(q).get("time").toString().length() > 2){
+                                continue;
+                            }else {
+                               // System.out.println(Integer.parseInt(dataAvbByMIdAndTime.get(q).get("time").toString())+"==="+j);
+                                String sj="";
+                                if (j<10){
+                                    sj="0"+j;
+                                }else {
+                                    if (j==24){
+                                        sj="00";
+                                    }else {
+                                        sj=""+j;
+                                    }
+                                }
+                                if (!timeList.contains(sj)){
+                                    map = new HashMap<>();
+                                    map.put("time",sj);
+                                    Map map1 = new HashMap();
+                                    map1.put("PM2_5","");
+                                    map1.put("NO2","");
+                                    map1.put("SO2","");
+                                    map1.put("O3","");
+                                    map1.put("PM10","");
+                                    map1.put("O3_8h","");
+                                    map1.put("CO","");
+                                    map.put("data",map1);
+                                    dataAvbByMIdAndTime.add(map);
+                                    break;
+                                }else {
+                                    break;
+                                }
+                            }
+                        }
+
+                    }
+                }
+                Collections.sort(dataAvbByMIdAndTime, new Comparator<Map<String, Object>>(){
+                    public int compare(Map<String, Object> o1, Map<String, Object> o2) {
+                        String name1 =(String)o1.get("time");//name1���������list������������������������
+                        String name2= (String)o2.get("time"); //name1���������list���������������������������name
+                        return name1.compareTo(name2);
+                    }
+                });
+                Map map1 = dataAvbByMIdAndTime.get(0);
+                dataAvbByMIdAndTime.remove(0);
+                dataAvbByMIdAndTime.add(map1);
+                for (int j = 0; j <dataAvbByMIdAndTime.size() ; j++) {
+                    if (dataAvbByMIdAndTime.get(j).get("time").toString().length()>2){
+                        Map map2 = dataAvbByMIdAndTime.get(j);
+                        dataAvbByMIdAndTime.remove(j);
+                        dataAvbByMIdAndTime.add(map2);
+                    }
+                }
                 lists.add(dataAvbByMIdAndTime);
             }
             List<Map<String, Object>> dataByMonitorPoints = historyHourlyService.getDataByMonitorPoints(mIds, date1, date2);
             lists.add(dataByMonitorPoints);
         }
-        return new ResultBean<List<List<Map<String,Object>>>>(lists);
+        List<Map<String, Object>> rList =new ArrayList<>();
+        if (lists.size()==1 && lists.get(0)!=null){
+            for (int i = 0; i < lists.get(0).size(); i++) {
+                List list = new ArrayList();
+                list.add(lists.get(0).get(i).get("data"));
+                Map map = new HashMap();
+                map.put("data",list);
+                map.put("time",lists.get(0).get(i).get("time"));
+                rList.add(map);
+            }
+
+        } else if (lists.size()==1 && lists.get(0)==null){
+            rList.add(null);
+        }else {
+            for (int j = 0; j < lists.get(0).size(); j++) {
+                Map<String, Object> listMap = new HashMap();
+                List<Map> mapList = new ArrayList<>();
+                if (lists.get(0).size() == 1) {
+                    mapList.add(null);
+                } else {
+                    mapList.add((Map) lists.get(0).get(j).get("data"));
+                }
+                for (int i = 1; i < lists.size(); i++) {
+                    if (lists.get(i).size() == 1) {
+                        mapList.add(null);
+                        listMap.put("data", mapList);
+                    } else {
+                        if (lists.get(0).get(j).get("time").equals(lists.get(i).get(j).get("time"))) {
+                            mapList.add((Map) lists.get(i).get(j).get("data"));
+                        }
+                        listMap.put("time", lists.get(0).get(j).get("time"));
+                        listMap.put("data", mapList);
+                    }
+                }
+                rList.add(listMap);
+            }
+        }
+        return new ResultBean<List<Map<String,Object>>>(rList);
     }
-}
+}
\ No newline at end of file
diff --git a/src/main/java/com/moral/service/impl/HistoryHourlyServiceImpl.java b/src/main/java/com/moral/service/impl/HistoryHourlyServiceImpl.java
index f2d502c..c5272bf 100644
--- a/src/main/java/com/moral/service/impl/HistoryHourlyServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/HistoryHourlyServiceImpl.java
@@ -325,14 +325,14 @@
                     int time1 = Integer.parseInt(mapList1.get(j).get("time").toString()) ;
                     if (time==time1){
                         Double O3_8h = Double.parseDouble(mapList1.get(j).get("O3_8h").toString());
-                        dataAvbByMIdAndTime.get(i).put("O3_8h",new BigDecimal(O3_8h).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+                        dataAvbByMIdAndTime.get(i).put("O3_8h",new BigDecimal(O3_8h).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
                     }
                 }
             }
         }
       Map<String, Object> dailyAvgData = historyMapper.getDailyAvgData(mId, startTime);
           if (dailyAvgData!=null){
-            dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+            dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
         }
         List<Map<String,Object>> finalList = new ArrayList<>();
         for (int i = 0; i <dataAvbByMIdAndTime.size() ; i++) {
@@ -346,13 +346,12 @@
         Map<String,Object> timeAndDate = new HashMap();
         String time = startTime.substring(0,11);
         timeAndDate.put("time",time);
-        if (dailyAvgData==null){
+        if (dailyAvgData!=null){
             //List<Map<String, Object>> dailyData = historyHourlyMapper.getDataAvbByMIdAndT;
-            timeAndDate.put("data","");
-        }else {
             timeAndDate.put("data",dailyAvgData);
+        }else {
+            timeAndDate.put("data","");
         }
-
         finalList.add(timeAndDate);
         Map<String,Object> map = new HashMap<>();
         map.put("maxO3",maxO3);
@@ -427,7 +426,7 @@
                     int time1 = Integer.parseInt(mapList1.get(j).get("time").toString()) ;
                     if (time==time1){
                         Double O3_8h = Double.parseDouble(mapList1.get(j).get("O3_8h").toString());
-                        dataByMonitorPoints.get(i).put("O3_8h",new BigDecimal(O3_8h).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+                        dataByMonitorPoints.get(i).put("O3_8h",new BigDecimal(O3_8h).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
                     }
                 }
             }
@@ -445,14 +444,28 @@
         Map<String, Object> dailyAvgData = historyMapper.getDailyAvgDataByMIds(mIds, startTime);
         if (dailyAvgData!=null){
             Map<String,Object> timeAndDate = new HashMap();
-            dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+            dailyAvgData.put("maxO3_8h",new BigDecimal(maxO3).setScale(0,BigDecimal.ROUND_HALF_UP).doubleValue());
             timeAndDate.put("data",dailyAvgData);
             timeAndDate.put("time",startTime.substring(0,11));
             finalList.add(timeAndDate);
         }else {
             Map<String, Object> avgDataByMIds = historyHourlyMapper.getAvgDataByMIds(mIds, startTime, endTime);
             Map<String,Object> timeAndDate = new HashMap();
-            avgDataByMIds.put("maxO3_8h",new BigDecimal(maxO3).setScale(4,BigDecimal.ROUND_HALF_UP).doubleValue());
+            if (avgDataByMIds == null){
+                avgDataByMIds = new HashMap<>();
+                avgDataByMIds.put("PM2_5","");
+                avgDataByMIds.put("NO2","");
+                avgDataByMIds.put("primary_pollutants","-");
+                avgDataByMIds.put("SO2","");
+                avgDataByMIds.put("O3","");
+                avgDataByMIds.put("PM10","");
+                avgDataByMIds.put("O3_8h","");
+                avgDataByMIds.put("CO","");
+                avgDataByMIds.put("AQI","");
+            }else {
+                avgDataByMIds.put("maxO3_8h",maxO3);
+            }
+
             timeAndDate.put("data",avgDataByMIds);
             timeAndDate.put("time",startTime.substring(0,11));
             finalList.add(timeAndDate);
@@ -460,7 +473,7 @@
         for (int i=0;i<finalList.size();i++) {
             if (i!=finalList.size()-1){
                 Map<String, Object> map1 = AQICalculation2.hourlyAQI((Map<String, Object>) finalList.get(i).get("data"));
-                if (Double.parseDouble(map1.get("AQI").toString())>=50.0){
+                if (Double.parseDouble(map1.get("AQI").toString())>50.0){
                     ((Map<String, Object>) finalList.get(i).get("data")).put("primary_pollutants",map1.get("maxSensor"));
                     ((Map<String, Object>) finalList.get(i).get("data")).put("AQI",map1.get("AQI"));
                 }else {
@@ -469,6 +482,9 @@
                 }
             }else {
                 Map<String, Object> map1 = AQICalculation2.dayAQI((Map<String, Object>) finalList.get(i).get("data"));
+                if (map1.get("AQI").toString().equals("")){
+                    break;
+                }
                 if (Double.parseDouble(map1.get("AQI").toString())>=50.0){
                     ((Map<String, Object>) finalList.get(i).get("data")).put("primary_pollutants",map1.get("maxSensor"));
                     ((Map<String, Object>) finalList.get(i).get("data")).put("AQI",map1.get("AQI"));
@@ -481,10 +497,74 @@
         Map<String,Object> timeAndDate = new HashMap();
         String time = startTime.substring(0,11);
         timeAndDate.put("time",time);
-        if (dailyAvgData==null){
-            timeAndDate.put("data","");
-        }else {
+        if (dailyAvgData!=null){
             timeAndDate.put("data",dailyAvgData);
+        }else {
+            Map map = new HashMap<>();
+            Map map1 = new HashMap();
+            map1.put("PM2_5","");
+            map1.put("NO2","");
+            map1.put("primary_pollutants","-");
+            map1.put("SO2","");
+            map1.put("O3","");
+            map1.put("PM10","");
+            map1.put("O3_8h","");
+            map1.put("CO","");
+            map1.put("AQI","");
+            map.put("data",map1);
+            timeAndDate.put("data",map);
+        }
+        List timeList = new ArrayList();
+        for (int q = 0; q < finalList.size(); q++) {
+            timeList.add(finalList.get(q).get("time"));
+        }
+        if (finalList.size()<25){
+            for (int j = 1; j < 25; j++) {
+                Map<String,Object> map = null;
+                for (int q = 0; q < finalList.size(); q++) {
+                    if (finalList.get(q).get("time").toString().length() > 2){
+                        continue;
+                    }else {
+                        String sj="";
+                        if (j<10){
+                            sj="0"+j;
+                        }else {
+                            if (j==24){
+                                sj="00";
+                            }else {
+                                sj=""+j;
+                            }
+                        }
+                        if (!timeList.contains(sj)){
+                            map = new HashMap<>();
+                            Map map1 = new HashMap();
+                            map1.put("PM2_5","");
+                            map1.put("NO2","");
+                            map1.put("primary_pollutants","");
+                            map1.put("SO2","");
+                            map1.put("O3","");
+                            map1.put("PM10","");
+                            map1.put("O3_8h","");
+                            map1.put("CO","");
+                            map1.put("AQI","");
+                            map.put("time",sj);
+                            map.put("data",map1);
+                            finalList.add(map);
+                            break;
+                        }else {
+                            break;
+                        }
+                    }
+                }
+
+            }
+        }
+        for (int j = 0; j <finalList.size() ; j++) {
+            if (finalList.get(j).get("time").toString().length()>2){
+                Map map2 = finalList.get(j);
+                finalList.remove(j);
+                finalList.add(map2);
+            }
         }
         return finalList;
     }
diff --git a/src/main/java/com/moral/service/impl/HistoryServiceImpl.java b/src/main/java/com/moral/service/impl/HistoryServiceImpl.java
index 8007e0a..d914880 100644
--- a/src/main/java/com/moral/service/impl/HistoryServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/HistoryServiceImpl.java
@@ -412,8 +412,10 @@
             Map<String, Double> AQIMap = new HashMap<>();
             for (Map.Entry<String, Object> entry : map.entrySet()) {
                 String key = entry.getKey();
-                Double value = Double.parseDouble(entry.getValue().toString());
-                AQIMap.put(key, value);
+                if (entry.getValue() != null) {
+                    Double value = Double.parseDouble(entry.getValue().toString());
+                    AQIMap.put(key, value);
+                }
             }
             returnMap = AQICalculation.hourlyAQI(AQIMap);
         }
diff --git a/src/main/java/com/moral/util/AQICalculation2.java b/src/main/java/com/moral/util/AQICalculation2.java
index 050afdd..9797972 100644
--- a/src/main/java/com/moral/util/AQICalculation2.java
+++ b/src/main/java/com/moral/util/AQICalculation2.java
@@ -9,17 +9,23 @@
 		Map maxMap = new HashMap();
 		for (Map.Entry<String, Object> entry : map.entrySet()) {
 			String key = entry.getKey();
-			if (entry.getValue() instanceof Double){
-				Double value = Double.parseDouble(entry.getValue().toString());
-				if (key!="O3_8h"){
-					maxMap.put(key,value);
-				}
-				Double PM2_5AQI;
-				Double PM10AQI;
-				Double SO2AQI;
-				Double NO2AQI;
-				Double COAQI;
-				Double O3AQI;
+			if (entry.getValue().toString().equals("")){
+				continue;
+			}
+			Double value = Double.parseDouble(entry.getValue().toString());
+
+			if (key!="O3_8h"){
+				maxMap.put(key,value);
+			}else {
+				continue;
+			}
+			Double PM2_5AQI;
+			Double PM10AQI;
+			Double SO2AQI;
+			Double NO2AQI;
+			Double COAQI;
+			Double O3AQI;
+
 				switch (key) {
 					case "PM2_5":PM2_5AQI = PM2_5AQI(value);
 						AQIList.add(PM2_5AQI);
@@ -39,24 +45,17 @@
 					case "maxO3_8h":O3AQI = O3AQI(value);
 						AQIList.add(O3AQI);
 						break;
-
 					default:
 						break;
 				}
-			}else {
-				continue;
 			}
-			}
-
-		Double AQIMAX = Collections.max(AQIList);
 		Map<String, Object> returnMap = new HashMap<>();
-
-		Optional<Map.Entry<String, Integer>> max0 = maxMap.entrySet()
-				.stream()
-				.max(Map.Entry.comparingByValue());
-
-		returnMap.put("maxSensor",max0.get().getKey());
-		returnMap.put("AQI", AQIMAX);
+			Double AQIMAX = Collections.max(AQIList);
+			Optional<Map.Entry<String, Integer>> max0 = maxMap.entrySet()
+					.stream()
+					.max(Map.Entry.comparingByValue());
+			returnMap.put("maxSensor", max0.get().getKey());
+			returnMap.put("AQI", AQIMAX);
 		return returnMap;
 	}
 	public static Map<String, Object> dayAQI(Map<String, Object> map){
@@ -64,10 +63,14 @@
 		Map maxMap = new HashMap();
 		for (Map.Entry<String, Object> entry : map.entrySet()) {
 			String key = entry.getKey();
-			if (entry.getValue() instanceof Double){
+			if (entry.getValue().toString().equals("")){
+				continue;
+			}
 				Double value = Double.parseDouble(entry.getValue().toString());
 				if (key!="O3_day"){
 					maxMap.put(key,value);
+				}else {
+					continue;
 				}
 				Double PM2_5AQI;
 				Double PM10AQI;
@@ -97,19 +100,19 @@
 					default:
 						break;
 				}
-			}else {
-				continue;
-			}
 		}
-
-		Double AQIMAX = Collections.max(AQIList);
 		Map<String, Object> returnMap = new HashMap<>();
-		Optional<Map.Entry<String, Integer>> max0 = maxMap.entrySet()
-				.stream()
-				.max(Map.Entry.comparingByValue());
-
-		returnMap.put("maxSensor",max0.get().getKey());
-		returnMap.put("AQI", AQIMAX);
+		if (AQIList.size()>0){
+			Double AQIMAX = Collections.max(AQIList);
+			Optional<Map.Entry<String, Integer>> max0 = maxMap.entrySet()
+					.stream()
+					.max(Map.Entry.comparingByValue());
+			returnMap.put("maxSensor",max0.get().getKey());
+			returnMap.put("AQI", AQIMAX);
+		}else {
+			returnMap.put("maxSensor","");
+			returnMap.put("AQI", "");
+		}
 		return returnMap;
 	}
 	static double PM2_5AQI(Double value) {
diff --git a/src/main/resources/mapper/HistoryHourlyMapper.xml b/src/main/resources/mapper/HistoryHourlyMapper.xml
index e74be91..f71f671 100644
--- a/src/main/resources/mapper/HistoryHourlyMapper.xml
+++ b/src/main/resources/mapper/HistoryHourlyMapper.xml
@@ -112,15 +112,15 @@
     </select>
     <select id="getDataAvbByMIdAndTime" resultType="java.util.Map">
         select hh.time as `time`,
-            AVG(hh.json->"$.e1[0]") as `PM2_5`,AVG(hh.json->"$.e2[0]") as 'PM10',AVG(hh.json->"$.e10[0]") as 'CO',
-            AVG(hh.json->"$.e11[0]") as 'SO2',AVG(hh.json->"$.e16[0]") as 'NO2',AVG(hh.json->"$.e15[0]") as 'O3'
+            IFNULL(ROUND(AVG(hh.json->"$.e1[0]")),"") as `PM2_5`,IFNULL(ROUND(AVG(hh.json->"$.e2[0]")),"") as 'PM10',IFNULL(ROUND(AVG(hh.json->"$.e10[0]"),1),"") as 'CO',
+            IFNULL(ROUND(AVG(hh.json->"$.e11[0]")),"") as 'SO2',IFNULL(ROUND(AVG(hh.json->"$.e16[0]")),"") as 'NO2',IFNULL(ROUND(AVG(hh.json->"$.e15[0]")),"") as 'O3'
             from monitor_point mt,device d,history_hourly hh
             where mt.id=d.monitor_point_id and d.mac=hh.mac and mt.id=#{mId} and hh.time>#{startTime} and hh.time<![CDATA[<=]]>#{endTime} GROUP BY hh.time;
     </select>
     <select id="getDataByMonitorPoints" resultType="java.util.Map">
         select hh.time as `time`,
-        AVG(hh.json->"$.e1[0]") as `PM2_5`,AVG(hh.json->"$.e2[0]") as 'PM10',AVG(hh.json->"$.e10[0]") as 'CO',
-        AVG(hh.json->"$.e11[0]") as 'SO2',AVG(hh.json->"$.e16[0]") as 'NO2',AVG(hh.json->"$.e15[0]") as 'O3'
+        IFNULL(ROUND(AVG(hh.json->"$.e1[0]")),"") as `PM2_5`,IFNULL(ROUND(AVG(hh.json->"$.e2[0]")),"") as 'PM10',IFNULL(ROUND(AVG(hh.json->"$.e10[0]"),1),"") as 'CO',
+        IFNULL(ROUND(AVG(hh.json->"$.e11[0]")),"") as 'SO2',IFNULL(ROUND(AVG(hh.json->"$.e16[0]")),"") as 'NO2',IFNULL(ROUND(AVG(hh.json->"$.e15[0]")),"") as 'O3'
         from monitor_point mt,device d,history_hourly hh
         where mt.id=d.monitor_point_id and d.mac=hh.mac and mt.id in
         <foreach collection="mIds" item="id" index="index" open="(" close=")" separator=",">
@@ -129,14 +129,16 @@
         and hh.time>#{startTime} and hh.time<![CDATA[<=]]>#{endTime} GROUP BY hh.time;
     </select>
     <select id="getAvgDataByMId" resultType="java.util.Map">
-        SELECT AVG(hh.json->"$.e1[0]") as `PM2_5`,AVG(hh.json->"$.e2[0]") as 'PM10',AVG(hh.json->"$.e10[0]") as 'CO',
-        AVG(hh.json->"$.e11[0]") as 'SO2',AVG(hh.json->"$.e16[0]") as 'NO2',AVG(hh.json->"$.e15[0]") as 'O3_day'
+        SELECT
+        IFNULL(ROUND(AVG(hh.json->"$.e1[0]")),"") as `PM2_5`,IFNULL(ROUND(AVG(hh.json->"$.e2[0]")),"") as 'PM10',IFNULL(ROUND(AVG(hh.json->"$.e10[0]"),1),"") as 'CO',
+        IFNULL(ROUND(AVG(hh.json->"$.e11[0]")),"") as 'SO2',IFNULL(ROUND(AVG(hh.json->"$.e16[0]")),"") as 'NO2',IFNULL(ROUND(AVG(hh.json->"$.e15[0]")),"") as 'O3_day'
         from monitor_point mt,device d,history_hourly hh where mt.id=d.monitor_point_id
         and d.mac=hh.mac and mt.id =#{mId} and hh.time<![CDATA[<=]]>#{endTime} and hh.time>#{startTime}
     </select>
     <select id="getAvgDataByMIds" resultType="java.util.Map">
-        SELECT AVG(hh.json->"$.e1[0]") as `PM2_5`,AVG(hh.json->"$.e2[0]") as 'PM10',AVG(hh.json->"$.e10[0]") as 'CO',
-        AVG(hh.json->"$.e11[0]") as 'SO2',AVG(hh.json->"$.e16[0]") as 'NO2',AVG(hh.json->"$.e15[0]") as 'O3_day'
+        SELECT
+        IFNULL(ROUND(AVG(hh.json->"$.e1[0]")),"") as `PM2_5`,IFNULL(ROUND(AVG(hh.json->"$.e2[0]")),"") as 'PM10',IFNULL(ROUND(AVG(hh.json->"$.e10[0]"),1),"") as 'CO',
+        IFNULL(ROUND(AVG(hh.json->"$.e11[0]")),"") as 'SO2',IFNULL(ROUND(AVG(hh.json->"$.e16[0]")),"") as 'NO2',IFNULL(ROUND(AVG(hh.json->"$.e15[0]")),"") as 'O3_day'
         from monitor_point mt,device d,history_hourly hh where mt.id=d.monitor_point_id
         and d.mac=hh.mac and mt.id in
         <foreach collection="mIds" item="id" index="index" open="(" close=")" separator=",">
diff --git a/src/main/resources/mapper/HistoryMapper.xml b/src/main/resources/mapper/HistoryMapper.xml
index 08223f6..47bd34f 100644
--- a/src/main/resources/mapper/HistoryMapper.xml
+++ b/src/main/resources/mapper/HistoryMapper.xml
@@ -301,14 +301,16 @@
         limit 0,1
     </select>
     <select id="getDailyAvgData" resultType="java.util.Map">
-        SELECT  AVG(hd.json->"$.e1[0]") as `PM2_5`,AVG(hd.json->"$.e2[0]") as 'PM10',AVG(hd.json->"$.e10[0]") as 'CO',
-            AVG(hd.json->"$.e11[0]") as 'SO2',AVG(hd.json->"$.e16[0]") as 'NO2',AVG(hd.json->"$.e15[0]") as 'O3_day'
-            FROM `history_daily` hd,monitor_point mt,device d where mt.id=d.monitor_point_id
+        SELECT
+        IFNULL(ROUND(AVG(hd.json->"$.e1[0]")),"") as `PM2_5`,IFNULL(ROUND(AVG(hd.json->"$.e2[0]")),"") as 'PM10',IFNULL(ROUND(AVG(hd.json->"$.e10[0]"),1),"") as 'CO',
+        IFNULL(ROUND(AVG(hd.json->"$.e11[0]")),"") as 'SO2',IFNULL(ROUND(AVG(hd.json->"$.e16[0]")),"") as 'NO2',IFNULL(ROUND(AVG(hd.json->"$.e15[0]")),"") as 'O3_day'
+        FROM `history_daily` hd,monitor_point mt,device d where mt.id=d.monitor_point_id
             and d.mac=hd.mac and mt.id=#{mId} and time=#{time}
     </select>
     <select id="getDailyAvgDataByMIds" resultType="java.util.Map">
-        SELECT  AVG(hd.json->"$.e1[0]") as `PM2_5`,AVG(hd.json->"$.e2[0]") as 'PM10',AVG(hd.json->"$.e10[0]") as 'CO',
-            AVG(hd.json->"$.e11[0]") as 'SO2',AVG(hd.json->"$.e16[0]") as 'NO2',AVG(hd.json->"$.e15[0]") as 'O3_day'
+        SELECT
+        IFNULL(ROUND(AVG(hd.json->"$.e1[0]")),"") as `PM2_5`,IFNULL(ROUND(AVG(hd.json->"$.e2[0]")),"") as 'PM10',IFNULL(ROUND(AVG(hd.json->"$.e10[0]"),1),"") as 'CO',
+        IFNULL(ROUND(AVG(hd.json->"$.e11[0]")),"") as 'SO2',IFNULL(ROUND(AVG(hd.json->"$.e16[0]")),"") as 'NO2',IFNULL(ROUND(AVG(hd.json->"$.e15[0]")),"") as 'O3_day'
             FROM `history_daily` hd,monitor_point mt,device d where mt.id=d.monitor_point_id
             and d.mac=hd.mac and mt.id in
         <foreach collection="mIds" item="id" index="index" open="(" close=")" separator=",">

--
Gitblit v1.8.0