| | |
| | | <select id="getHourlySensorData" resultType="java.util.LinkedHashMap"> |
| | | SELECT |
| | | h.mac, |
| | | <foreach collection="sensorKeys" separator="," item="sensorKey"> |
| | | AVG(json->'$.${sensorKey}[0]') AS '${sensorKey}', |
| | | MIN(json->'$.${sensorKey}[1]') AS 'MIN${sensorKey}', |
| | | MAX(json->'$.${sensorKey}[2]') AS 'MAX${sensorKey}' |
| | | <foreach collection="sensorKeys" separator="," item="sensorKey"> |
| | | <choose > |
| | | <when test="sensorKey=='e23'"> |
| | | ROUND((CASE WHEN AVG(json->'$.e18[0]'*SIN((json->'$.e23[0]'/180)*PI()))<![CDATA[>]]>0 AND AVG(json->'$.e18[0]'*COS((json->'$.e23[0]'/180)*PI()))<![CDATA[>]]>0 |
| | | THEN ATAN(AVG(json->'$.e18[0]'*SIN((json->'$.e23[0]'/180)*PI()))/AVG(json->'$.e18[0]'*COS((json->'$.e23[0]'/180)*PI())))*180/PI() |
| | | WHEN AVG(json->'$.e18[0]'*SIN((json->'$.e23[0]'/180)*PI()))>0 AND AVG(json->'$.e18[0]'*COS((json->'$.e23[0]'/180)*PI()))<![CDATA[<]]>0 |
| | | THEN (ATAN(AVG(json->'$.e18[0]'*SIN((json->'$.e23[0]'/180)*PI()))/AVG(json->'$.e18[0]'*COS((json->'$.e23[0]'/180)*PI())))*180/PI())+180 |
| | | WHEN AVG(json->'$.e18[0]'*SIN((json->'$.e23[0]'/180)*PI()))<![CDATA[<]]>0 AND AVG(json->'$.e18[0]'*COS((json->'$.e23[0]'/180)*PI()))<![CDATA[<]]>0 |
| | | THEN (ATAN(AVG(json->'$.e18[0]'*SIN((json->'$.e23[0]'/180)*PI()))/AVG(json->'$.e18[0]'*COS((json->'$.e23[0]'/180)*PI())))*180/PI())+180 |
| | | ELSE (ATAN(AVG(json->'$.e18[0]'*SIN((json->'$.e23[0]'/180)*PI()))/AVG(json->'$.e18[0]'*COS((json->'$.e23[0]'/180)*PI())))*180/PI())+360 |
| | | END),3) AS '${sensorKey}', |
| | | MIN(json->'$.${sensorKey}[1]') AS 'MIN${sensorKey}', |
| | | MAX(json->'$.${sensorKey}[2]') AS 'MAX${sensorKey}' |
| | | </when> |
| | | <otherwise> |
| | | AVG(json->'$.${sensorKey}[0]') AS '${sensorKey}', |
| | | MIN(json->'$.${sensorKey}[1]') AS 'MIN${sensorKey}', |
| | | MAX(json->'$.${sensorKey}[2]') AS 'MAX${sensorKey}' |
| | | </otherwise> |
| | | </choose> |
| | | </foreach> |
| | | FROM |
| | | history_hourly h |
| | | WHERE |
| | | h.time >= #{start} |
| | | AND h.time <![CDATA[<]]> #{end} |
| | | AND h.mac in |
| | | AND h.mac in |
| | | <foreach collection="macs" open="(" separator="," close=")" |
| | | item="mac"> |
| | | #{mac} |
| | |
| | | h.mac |
| | | </select> |
| | | |
| | | <select id="getHourlySensorDataToCalculateO3" resultType="java.util.LinkedHashMap"> |
| | | SELECT |
| | | h.mac, |
| | | <foreach collection="sensorKeys" separator="," item="sensorKey"> |
| | | AVG(json->'$.${sensorKey}[0]') AS '${sensorKey}', |
| | | MIN(json->'$.${sensorKey}[1]') AS 'MIN${sensorKey}', |
| | | MAX(json->'$.${sensorKey}[2]') AS 'MAX${sensorKey}' |
| | | </foreach> |
| | | FROM |
| | | history_hourly h |
| | | WHERE |
| | | h.time = #{time} |
| | | AND h.mac in |
| | | <foreach collection="macList" open="(" separator="," close=")" |
| | | item="mac"> |
| | | #{mac} |
| | | </foreach> |
| | | group by |
| | | h.mac |
| | | </select> |
| | | |
| | | <insert id="insertHistoryO3Hourly"> |
| | | insert into |
| | | history_hourly_o3 |
| | | values |
| | | <foreach collection="list" item="map" separator=","> |
| | | (#{map.mac},#{map.time},#{map.json}) |
| | | </foreach> |
| | | </insert> |
| | | |
| | | <select id="getBeamByMacs" resultType="java.util.Map"> |
| | | SELECT |
| | | DATE_FORMAT(h.time,#{typeFormat}) time, |
| | | avg(h.json->'$.e12[0]') 'beam' |
| | | FROM history_hourly h |
| | | WHERE h.json->'$.e12[0]' is not null |
| | | and h.mac in |
| | | <foreach collection="macs" open="(" separator="," close=")" item="mac"> |
| | | #{mac} |
| | | </foreach> |
| | | and h.time in |
| | | <foreach collection="times" open="(" separator="," close=")" item="time"> |
| | | #{time} |
| | | </foreach> |
| | | group by h.time |
| | | </select> |
| | | |
| | | <select id="selectCountByMac" resultType="java.lang.Integer"> |
| | | SELECT count(1) FROM history_hourly |
| | | WHERE mac = #{mac} |
| | | AND `time` >= #{start} |
| | | AND `time` <![CDATA[<]]> #{end} |
| | | </select> |
| | | </mapper> |