于紫祥_1901
2020-11-18 fc1e6566611aa9f4311272aeb0e2da1d03d6c9bd
src/main/resources/mapper/HistoryMapper.xml
@@ -236,6 +236,26 @@
        h.time
    </select>
    <!-- 无人机落点 -->
    <select id="getUavSensorData" resultType="java.util.LinkedHashMap">
        SELECT
        DATE_FORMAT(h.time,'%Y-%m-%d %H:%i:%s') time,
        <foreach collection="sensorKeys" item="sensorKey" separator=",">
            h.value->'$.${sensorKey}' as '${sensorKey}'
        </foreach>
        FROM
        history_special as h
        <where>
            <if test="mac!=null">
                and h.mac = #{mac}
            </if>
            and h.time >= #{startTime}
            and h.time <![CDATA[<]]> #{endTime}
        </where>
        ORDER BY
        h.time
    </select>
    <select id="listGetSensorData" resultType="java.util.LinkedHashMap">
        SELECT
        DATE_FORMAT(h.time,'%Y-%m-%d %H:%i:%s') time,
@@ -254,15 +274,34 @@
        ORDER BY
        h.time
    </select>
    <select id="getO3AVG" resultType="java.lang.String">
        select AVG(history_hourly.json->'$.e15[0]')
        FROM history_hourly
         where time <![CDATA[>=]]>#{frontTime}
         and time <![CDATA[<]]>#{afterTime}
         and mac=#{mac}
    </select>
    <select id="getNum" resultType="java.lang.Integer">
        select count(*) from history_hourly where time <![CDATA[>=]]> #{timef} and time <![CDATA[<=]]> #{timea}
    </select>
    <select id="getO3AVG" resultType="java.util.LinkedHashMap">
         select DATE_FORMAT(time,'%Y-%m-%d %H:%i:%s') time,json->'$.e15[0]' as e15
         FROM history_hourly
         where time <![CDATA[>=]]>#{date}
         and time <![CDATA[<]]>#{nextDate}
         and mac=#{mac}
         ORDER BY `time`
    </select>
    <select id="getJsonData" resultType="java.lang.String">
        select `json` from ${table}
      where  time = #{time} and mac = #{mac}
    </select>
    <select id="getValueByMacAndTime" resultType="java.lang.String">
        select `value` from history
      where  mac = #{mac} and time &gt;= #{time1} and time &lt;=#{time}
        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
and d.mac=hd.mac and mt.id=#{mId} and time=#{time}
    </select>
</mapper>