<?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.monitor.dao.HistoryEntityMapper" >
|
<resultMap id="BaseResultMap" type="com.moral.monitor.entity.HistoryEntity" >
|
<id column="id" property="id" jdbcType="INTEGER" />
|
<result column="mac" property="mac" jdbcType="VARCHAR" />
|
<result column="sensor" property="sensor" jdbcType="VARCHAR" />
|
<result column="mac_key" property="macKey" jdbcType="VARCHAR" />
|
<result column="mac_value" property="macValue" jdbcType="DOUBLE" />
|
<result column="time" property="time" jdbcType="TIMESTAMP" />
|
</resultMap>
|
<sql id="Example_Where_Clause" >
|
<where >
|
<foreach collection="oredCriteria" item="criteria" separator="or" >
|
<if test="criteria.valid" >
|
<trim prefix="(" suffix=")" prefixOverrides="and" >
|
<foreach collection="criteria.criteria" item="criterion" >
|
<choose >
|
<when test="criterion.noValue" >
|
and ${criterion.condition}
|
</when>
|
<when test="criterion.singleValue" >
|
and ${criterion.condition} #{criterion.value}
|
</when>
|
<when test="criterion.betweenValue" >
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
</when>
|
<when test="criterion.listValue" >
|
and ${criterion.condition}
|
<foreach collection="criterion.value" item="listItem" open="(" close=")" separator="," >
|
#{listItem}
|
</foreach>
|
</when>
|
</choose>
|
</foreach>
|
</trim>
|
</if>
|
</foreach>
|
</where>
|
</sql>
|
<sql id="Update_By_Example_Where_Clause" >
|
<where >
|
<foreach collection="example.oredCriteria" item="criteria" separator="or" >
|
<if test="criteria.valid" >
|
<trim prefix="(" suffix=")" prefixOverrides="and" >
|
<foreach collection="criteria.criteria" item="criterion" >
|
<choose >
|
<when test="criterion.noValue" >
|
and ${criterion.condition}
|
</when>
|
<when test="criterion.singleValue" >
|
and ${criterion.condition} #{criterion.value}
|
</when>
|
<when test="criterion.betweenValue" >
|
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
</when>
|
<when test="criterion.listValue" >
|
and ${criterion.condition}
|
<foreach collection="criterion.value" item="listItem" open="(" close=")" separator="," >
|
#{listItem}
|
</foreach>
|
</when>
|
</choose>
|
</foreach>
|
</trim>
|
</if>
|
</foreach>
|
</where>
|
</sql>
|
<sql id="Base_Column_List" >
|
id, mac, sensor, mac_key, mac_value, time
|
</sql>
|
<select id="selectByExample" resultMap="BaseResultMap" parameterType="com.moral.monitor.entity.HistoryEntityExample" >
|
select
|
<if test="distinct" >
|
distinct
|
</if>
|
<include refid="Base_Column_List" />
|
from history
|
<if test="_parameter != null" >
|
<include refid="Example_Where_Clause" />
|
</if>
|
<if test="orderByClause != null" >
|
order by ${orderByClause}
|
</if>
|
</select>
|
<select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
|
select
|
<include refid="Base_Column_List" />
|
from history
|
where id = #{id,jdbcType=INTEGER}
|
</select>
|
<delete id="deleteByPrimaryKey" parameterType="java.lang.Integer" >
|
delete from history
|
where id = #{id,jdbcType=INTEGER}
|
</delete>
|
<delete id="deleteByExample" parameterType="com.moral.monitor.entity.HistoryEntityExample" >
|
delete from history
|
<if test="_parameter != null" >
|
<include refid="Example_Where_Clause" />
|
</if>
|
</delete>
|
<insert id="insert" parameterType="com.moral.monitor.entity.HistoryEntity" >
|
insert into history (id, mac, sensor,
|
mac_key, mac_value, time
|
)
|
values (#{id,jdbcType=INTEGER}, #{mac,jdbcType=VARCHAR}, #{sensor,jdbcType=VARCHAR},
|
#{macKey,jdbcType=VARCHAR}, #{macValue,jdbcType=DOUBLE}, #{time,jdbcType=TIMESTAMP}
|
)
|
</insert>
|
<insert id="insertSelective" parameterType="com.moral.monitor.entity.HistoryEntity" >
|
insert into history
|
<trim prefix="(" suffix=")" suffixOverrides="," >
|
<if test="id != null" >
|
id,
|
</if>
|
<if test="mac != null" >
|
mac,
|
</if>
|
<if test="sensor != null" >
|
sensor,
|
</if>
|
<if test="macKey != null" >
|
mac_key,
|
</if>
|
<if test="macValue != null" >
|
mac_value,
|
</if>
|
<if test="time != null" >
|
time,
|
</if>
|
</trim>
|
<trim prefix="values (" suffix=")" suffixOverrides="," >
|
<if test="id != null" >
|
#{id,jdbcType=INTEGER},
|
</if>
|
<if test="mac != null" >
|
#{mac,jdbcType=VARCHAR},
|
</if>
|
<if test="sensor != null" >
|
#{sensor,jdbcType=VARCHAR},
|
</if>
|
<if test="macKey != null" >
|
#{macKey,jdbcType=VARCHAR},
|
</if>
|
<if test="macValue != null" >
|
#{macValue,jdbcType=DOUBLE},
|
</if>
|
<if test="time != null" >
|
#{time,jdbcType=TIMESTAMP},
|
</if>
|
</trim>
|
</insert>
|
<select id="countByExample" parameterType="com.moral.monitor.entity.HistoryEntityExample" resultType="java.lang.Integer" >
|
select count(*) from history
|
<if test="_parameter != null" >
|
<include refid="Example_Where_Clause" />
|
</if>
|
</select>
|
<update id="updateByExampleSelective" parameterType="map" >
|
update history
|
<set >
|
<if test="record.id != null" >
|
id = #{record.id,jdbcType=INTEGER},
|
</if>
|
<if test="record.mac != null" >
|
mac = #{record.mac,jdbcType=VARCHAR},
|
</if>
|
<if test="record.sensor != null" >
|
sensor = #{record.sensor,jdbcType=VARCHAR},
|
</if>
|
<if test="record.macKey != null" >
|
mac_key = #{record.macKey,jdbcType=VARCHAR},
|
</if>
|
<if test="record.macValue != null" >
|
mac_value = #{record.macValue,jdbcType=DOUBLE},
|
</if>
|
<if test="record.time != null" >
|
time = #{record.time,jdbcType=TIMESTAMP},
|
</if>
|
</set>
|
<if test="_parameter != null" >
|
<include refid="Update_By_Example_Where_Clause" />
|
</if>
|
</update>
|
<update id="updateByExample" parameterType="map" >
|
update history
|
set id = #{record.id,jdbcType=INTEGER},
|
mac = #{record.mac,jdbcType=VARCHAR},
|
sensor = #{record.sensor,jdbcType=VARCHAR},
|
mac_key = #{record.macKey,jdbcType=VARCHAR},
|
mac_value = #{record.macValue,jdbcType=DOUBLE},
|
time = #{record.time,jdbcType=TIMESTAMP}
|
<if test="_parameter != null" >
|
<include refid="Update_By_Example_Where_Clause" />
|
</if>
|
</update>
|
<update id="updateByPrimaryKeySelective" parameterType="com.moral.monitor.entity.HistoryEntity" >
|
update history
|
<set >
|
<if test="mac != null" >
|
mac = #{mac,jdbcType=VARCHAR},
|
</if>
|
<if test="sensor != null" >
|
sensor = #{sensor,jdbcType=VARCHAR},
|
</if>
|
<if test="macKey != null" >
|
mac_key = #{macKey,jdbcType=VARCHAR},
|
</if>
|
<if test="macValue != null" >
|
mac_value = #{macValue,jdbcType=DOUBLE},
|
</if>
|
<if test="time != null" >
|
time = #{time,jdbcType=TIMESTAMP},
|
</if>
|
</set>
|
where id = #{id,jdbcType=INTEGER}
|
</update>
|
<update id="updateByPrimaryKey" parameterType="com.moral.monitor.entity.HistoryEntity" >
|
update history
|
set mac = #{mac,jdbcType=VARCHAR},
|
sensor = #{sensor,jdbcType=VARCHAR},
|
mac_key = #{macKey,jdbcType=VARCHAR},
|
mac_value = #{macValue,jdbcType=DOUBLE},
|
time = #{time,jdbcType=TIMESTAMP}
|
where id = #{id,jdbcType=INTEGER}
|
</update>
|
<select id="getMonthAverageBySensor" resultType="map">
|
SELECT
|
AVG(mac_value) average
|
FROM
|
history
|
WHERE
|
mac = #{mac,jdbcType=VARCHAR}
|
AND mac_key = #{macKey,jdbcType=VARCHAR}
|
AND time > #{start,jdbcType=TIMESTAMP}
|
AND time < #{end,jdbcType=TIMESTAMP}
|
</select>
|
|
<select id="getAverageByAll" resultType="map">
|
SELECT
|
<if test="macKey != null and macKey != 'all'">
|
e.name,
|
</if>
|
<if test="macKey == 'all'">
|
h.mac_key,
|
</if>
|
AVG(h.mac_value) avg
|
FROM
|
history h,
|
monitorpoint m,
|
equipment e
|
WHERE
|
m.areacode = #{areaCode}
|
AND m.id = e.monitorpoint
|
AND e.mac = h.mac
|
AND h.time > #{start}
|
AND h.time < #{end}
|
<if test="orgIds != null and orgIds.size > 0">
|
<!-- JOIN org_equ oe ON e.id = oe.equid -->
|
AND e.owner_id IN
|
<foreach collection="orgIds" item="listItem" open="(" separator="," close=")" >
|
#{listItem}
|
</foreach>
|
</if>
|
<if test="macKey != null and macKey != 'all'">
|
AND h.mac_key = #{macKey}
|
GROUP BY e.id
|
ORDER BY avg
|
</if>
|
<if test="macKey == 'all'">
|
GROUP BY h.mac_key
|
</if>
|
</select>
|
|
<select id="getEquipmentStates" resultType="map">
|
SELECT
|
COUNT(state) count,
|
state
|
FROM
|
equipment
|
<if test="orgIds != null and orgIds.size > 0">
|
<!-- JOIN org_equ oe ON e.id = oe.equid -->
|
where owner_id IN
|
<foreach collection="orgIds" item="listItem" open="(" separator="," close=")" >
|
#{listItem}
|
</foreach>
|
</if>
|
GROUP BY state
|
</select>
|
|
<select id="getSensorsAverageByEquipment" resultType="map">
|
SELECT
|
concat(time,':00') AS 'time',
|
MAX(CASE WHEN mac_key='e1' THEN mac_value END) AS 'e1',
|
MAX(CASE WHEN mac_key='e2' THEN mac_value END) AS 'e2',
|
MAX(CASE WHEN mac_key='e3' THEN mac_value END) AS 'e3',
|
MAX(CASE WHEN mac_key='e4' THEN mac_value END) AS 'e4',
|
MAX(CASE WHEN mac_key='e5' THEN mac_value END) AS 'e5',
|
MAX(CASE WHEN mac_key='e6' THEN mac_value END) AS 'e6',
|
MAX(CASE WHEN mac_key='e7' THEN mac_value END) AS 'e7',
|
MAX(CASE WHEN mac_key='e8' THEN mac_value END) AS 'e8',
|
MAX(CASE WHEN mac_key='e9' THEN mac_value END) AS 'e9',
|
MAX(CASE WHEN mac_key='e10' THEN mac_value END) AS 'e10',
|
MAX(CASE WHEN mac_key='e11' THEN mac_value END) AS 'e11',
|
MAX(CASE WHEN mac_key='e12' THEN mac_value END) AS 'e12',
|
MAX(CASE WHEN mac_key='e13' THEN mac_value END) AS 'e13',
|
MAX(CASE WHEN mac_key='e14' THEN mac_value END) AS 'e14',
|
MAX(CASE WHEN mac_key='e15' THEN mac_value END) AS 'e15',
|
MAX(CASE WHEN mac_key='e16' THEN mac_value END) AS 'e16',
|
MAX(CASE WHEN mac_key='e17' THEN mac_value END) AS 'e17',
|
MAX(CASE WHEN mac_key='e18' THEN mac_value END) AS 'e18',
|
MAX(CASE WHEN mac_key='e19' THEN mac_value END) AS 'e19'
|
FROM
|
(
|
SELECT
|
h.mac_key,
|
DATE_FORMAT(time, #{type}) time,
|
AVG(h.mac_value) mac_value
|
FROM
|
history h
|
WHERE
|
h.mac = #{mac}
|
AND h.time >= #{start}
|
AND h.time < #{end}
|
GROUP BY
|
h.mac_key,
|
DATE_FORMAT(time, #{type})
|
ORDER BY
|
DATE_FORMAT(time, #{type})
|
) a
|
GROUP BY
|
time
|
</select>
|
</mapper>
|