<?xml version="1.0" encoding="UTF-8"?>
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<mapper namespace="com.moral.mapper.HistoryMapper">
|
<select id="selectValueByMacAndTime" resultType="java.lang.String">
|
select `value` from history_${timeUnits}
|
where time = #{time} and mac = #{mac}
|
limit 0,1
|
</select>
|
|
<select id="getAreaAllDataByAccount" resultType="java.util.LinkedHashMap">
|
SELECT
|
<if test="macKey != null">
|
d.`name`,
|
</if>
|
<foreach collection="sensorKeys" separator="," item="sensorKey">
|
AVG(h.json ->'$.${sensorKey}[0]') AS '${sensorKey}'
|
</foreach>
|
FROM
|
history_${timeUnits} h,
|
device d,
|
monitor_point mp
|
WHERE
|
h.mac = d.mac
|
AND d.monitor_point_id = mp.id
|
<if test="areaCode != null">
|
AND mp.area_code = #{areaCode}
|
</if>
|
<if test="start != null">
|
AND h.time >= #{start}
|
</if>
|
<if test="end != null">
|
AND h.time < #{end}
|
</if>
|
<if test="monitorPointId != null">
|
AND mp.id = #{monitorPointId}
|
</if>
|
<if test="orgIds != null and orgIds.size > 0">
|
AND mp.organization_id IN
|
<foreach collection="orgIds" open="(" separator="," close=")"
|
item="listItem">
|
#{listItem}
|
</foreach>
|
</if>
|
<if test="macKey != null">
|
GROUP BY d.id
|
ORDER BY ${macKey} desc
|
</if>
|
</select>
|
|
<select id="getRegionRankingData" resultType="java.util.Map">
|
SELECT
|
AVG( h.${column} -> '$.${sensorKey}[0]' ) avg ,
|
<if test="dimension == 'profession'">
|
p.`name`
|
</if>
|
<if test="dimension == 'monitorPoint'">
|
mp.`name`
|
</if>
|
<if test="dimension == 'region'">
|
r.${nextLevel}_name AS 'name'
|
</if>
|
FROM
|
<if test="dimension == 'profession'">
|
profession p ,
|
</if>
|
<if test="dimension == 'region'">
|
${nextLevel} r,
|
</if>
|
device d,
|
${table} h,
|
monitor_point mp
|
WHERE
|
d.mac = h.mac
|
AND d.is_delete = '0'
|
AND mp.is_delete = '0'
|
AND d.monitor_point_id = mp.id
|
AND h.time >= #{start}
|
AND mp.${regionType}_code = #{regionCode}
|
<if test="dimension == 'profession'">
|
AND d.profession_id = p.id
|
</if>
|
<if test="dimension == 'region'">
|
AND r.${nextLevel}_code = mp.${nextLevel}_code
|
</if>
|
<if test="orgIds != null and orgIds.size > 0">
|
AND mp.organization_id IN
|
<foreach collection="orgIds" open="(" separator="," close=")" item="listItem">
|
#{listItem}
|
</foreach>
|
</if>
|
GROUP BY
|
<if test="dimension == 'profession'">
|
p.id
|
</if>
|
<if test="dimension == 'monitorPoint'">
|
mp.id
|
</if>
|
<if test="dimension == 'region'">
|
mp.${nextLevel}_code
|
</if>
|
ORDER BY
|
avg DESC
|
<if test="dimension == 'monitorPoint'">
|
LIMIT 0,50
|
</if>
|
</select>
|
|
<select id="selectNextLevelRegion" resultType="string">
|
SELECT
|
${nextLevel}_name AS 'name'
|
FROM
|
${nextLevel}
|
WHERE
|
${regionType}_code = #{regionCode}
|
</select>
|
|
<select id="getDischargeByRegion" resultType="java.util.Map">
|
SELECT
|
mp.`name`,
|
dis.`value` -> '$.${sensorKey}' 'value'
|
FROM
|
monitor_point mp,
|
discharge dis
|
WHERE
|
dis.monitor_point_id = mp.id
|
AND mp.${regionType}_code = #{regionCode}
|
AND dis.`year` = #{year}
|
</select>
|
|
<select id="getValueByMacAndSize" resultType="java.util.Map">
|
SELECT
|
value,
|
time
|
FROM
|
history_${timeUnits}
|
WHERE
|
mac = #{mac}
|
ORDER BY
|
time DESC
|
LIMIT #{size}
|
</select>
|
|
<select id="getActualDataByRegion" resultType="java.util.Map">
|
SELECT
|
<foreach collection="sensorKeys" separator="," item="sensorKey">
|
MAX( `value` -> '$.${sensorKey}' ) * 1 AS '${sensorKey}'
|
</foreach>
|
FROM
|
history_${timeUnits} h ,
|
device d,
|
monitor_point mp
|
<where>
|
h.mac = d.mac
|
AND d.monitor_point_id = mp.id
|
<if test="orgIds != null and orgIds.size > 0">
|
AND mp.organization_id IN
|
<foreach collection="orgIds" open="(" separator="," close=")" item="listItem">
|
#{listItem}
|
</foreach>
|
</if>
|
AND h.time >= #{start}
|
AND h.time < #{end}
|
</where>
|
</select>
|
|
<select id="getAVGValueByMacAndTimeslot" resultType="java.util.Map">
|
SELECT AVG(JSON_EXTRACT(value,'$.e1')) e1,AVG(JSON_EXTRACT(value,'$.e2')) e2,AVG(JSON_EXTRACT(value,'$.e10')) e10,AVG(JSON_EXTRACT(value,'$.e11')) e11,AVG(JSON_EXTRACT(value,'$.e16')) e16,AVG(JSON_EXTRACT(value,'$.e15')) e15
|
FROM history_${timeUnits}
|
WHERE mac = #{mac}
|
AND time >= #{starttime}
|
AND time <![CDATA[<]]> #{endtime}
|
</select>
|
|
<!-- 无人机sensor当天查询 -->
|
<select id="getSensorDataToday" resultType="java.util.LinkedHashMap">
|
SELECT
|
DATE_FORMAT(time,'%Y-%m-%d %H:%i') time,
|
<foreach collection="sensorKeys" separator="," item="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
|
<where>
|
<if test="mac!=null">
|
and h.mac = #{mac}
|
</if>
|
and h.time >= #{startTime}
|
and h.time <![CDATA[<=]]> #{endTime}
|
</where>
|
GROUP BY
|
DATE_FORMAT(time,'%Y-%m-%d %H:%i')
|
ORDER BY
|
time
|
</select>
|
|
<select id="getAVGSensorRankByMonitorPointIdList" resultType="java.util.Map">
|
SELECT mp.name, AVG(JSON_EXTRACT(h.value,'$.${sensor}')) sensor
|
FROM device d, history_${timeUnits} 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}')) DESC
|
</select>
|
|
<select id="getMonitorPointAVGValueByMonitorPointIdAndTimeslot" resultType="java.util.Map">
|
SELECT AVG(JSON_EXTRACT(value,'$.e1')) e1,AVG(JSON_EXTRACT(value,'$.e2')) e2,AVG(JSON_EXTRACT(value,'$.e10')) e10,AVG(JSON_EXTRACT(value,'$.e11')) e11,AVG(JSON_EXTRACT(value,'$.e16')) e16,AVG(JSON_EXTRACT(value,'$.e15')) e15
|
FROM device d,history_${timeUnits} h
|
WHERE d.monitor_point_id = #{monitor_point_id}
|
AND d.mac = h.mac
|
AND h.time >= #{starttime}
|
AND h.time <![CDATA[<]]> #{endtime}
|
</select>
|
|
<!-- 走航车sensor查询 -->
|
<select id="getCarSensorData" 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="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,
|
<foreach collection="sensorKeys" item="sensorKey" separator=",">
|
h.value->'$.${sensorKey}' as '${sensorKey}'
|
</foreach>
|
FROM
|
history 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="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_${timeUnits}
|
where mac = #{mac} and time >= #{time1} and time <=#{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>
|
<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'
|
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=",">
|
#{id}
|
</foreach>
|
and time=#{time}
|
</select>
|
</mapper>
|