From e8ef361dc975aeaedeee6f28dfe679489a22f9d5 Mon Sep 17 00:00:00 2001
From: ZhuDongming <773644075@qq.com>
Date: Mon, 02 Sep 2019 17:42:06 +0800
Subject: [PATCH] Merge branch 'master' of http://blit.7drlb.com:8888/r/screen_api_v2

---
 src/main/resources/mapper/HistoryMapper.xml |   27 ++++++++++++++++++++++++++-
 1 files changed, 26 insertions(+), 1 deletions(-)

diff --git a/src/main/resources/mapper/HistoryMapper.xml b/src/main/resources/mapper/HistoryMapper.xml
index d200aa3..7835d14 100644
--- a/src/main/resources/mapper/HistoryMapper.xml
+++ b/src/main/resources/mapper/HistoryMapper.xml
@@ -175,7 +175,9 @@
         SELECT
         DATE_FORMAT(time,'%Y-%m-%d %H:%i') time,
         <foreach collection="sensorKeys" separator="," item="sensorKey">
-            AVG(h.value ->'$.${sensorKey}') AS '${sensorKey}'
+            AVG(h.value ->'$.${sensorKey}') AS '${sensorKey}',
+            MIN(cast(h.value ->'$.${sensorKey}' as decimal(11,5))) AS 'min${sensorKey}',
+            MAX(cast(h.value ->'$.${sensorKey}' as decimal(11,5))) AS 'max${sensorKey}'
         </foreach>
         FROM
         history h
@@ -191,4 +193,27 @@
         ORDER BY
         time
     </select>
+    
+    <select id="getAVGSensorRankByMonitorPointIdList" resultType="java.util.Map">
+    	SELECT mp.name, AVG(JSON_EXTRACT(h.value,'$.${sensor}[0]')) sensor
+		FROM device d, history h, monitor_point mp
+		WHERE d.mac=h.mac
+		And mp.id=d.monitor_point_id
+		AND d.monitor_point_id IN
+			<foreach collection="monitorPointIdList" index="index" item="monitorPointId" open="(" separator="," close=")">  
+	            #{monitorPointId}  
+	        </foreach>
+		AND h.time BETWEEN #{before5Time} AND #{endTime}
+		GROUP BY d.monitor_point_id
+		ORDER BY AVG(JSON_EXTRACT(h.value,'$.${sensor}[0]')) DESC
+    </select>
+    
+    <select id="getMonitorPointAVGValueByMonitorPointIdAndTimeslot" resultType="java.util.Map">
+    	SELECT AVG(JSON_EXTRACT(value,'$.e1[0]')) e1,AVG(JSON_EXTRACT(value,'$.e2[0]')) e2,AVG(JSON_EXTRACT(value,'$.e10[0]')) e10,AVG(JSON_EXTRACT(value,'$.e11[0]')) e11,AVG(JSON_EXTRACT(value,'$.e16[0]')) e16,AVG(JSON_EXTRACT(value,'$.e15[0]')) e15
+		FROM device d,history h
+		WHERE d.monitor_point_id = #{monitor_point_id}
+		AND d.mac = h.mac
+		AND h.time BETWEEN #{starttime} AND #{endtime}
+    </select>
+
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0