<?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
|
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.`value` ->'$.${sensorKey}[0]') AS '${sensorKey}'
|
</foreach>
|
FROM
|
history h,
|
device d,
|
monitor_point mp
|
WHERE
|
mp.area_code = #{areaCode}
|
AND h.time >= #{start}
|
AND h.time < #{end}
|
AND 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>
|
<if test="macKey != null">
|
GROUP BY d.id
|
ORDER BY ${macKey} desc
|
</if>
|
</select>
|
|
<select id="getRegionRankingData" resultType="java.util.Map">
|
SELECT
|
AVG( h.`value` -> '$.${sensorKey}[0]' ) avg ,
|
<if test="dimension == 'profession'">
|
p.`name`
|
</if>
|
<if test="dimension == 'monitorPoint'">
|
mp.`name`
|
</if>
|
<if test="dimension == 'region'">
|
mp.${nextLevel}_code AS 'code'
|
</if>
|
FROM
|
<if test="dimension == 'profession'">
|
profession p ,
|
</if>
|
device d,
|
history 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} = #{regionCode}
|
<if test="dimension == 'profession'">
|
AND d.profession_id = p.id
|
</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="java.util.Map">
|
SELECT
|
${nextLevel}_code AS 'code',
|
${nextLevel}_name AS 'name'
|
FROM
|
${nextLevel}
|
WHERE
|
${regionType} = #{regionCode}
|
</select>
|
</mapper>
|