Newer
Older
newfiber-termite / newfiber-termites / newfiber-termites-dataup / src / main / resources / mapper / termite / DeviceMonitoringDataRealtimeMapper.xml
@xiongkai xiongkai 6 days ago 4 KB 统计bug修复
<?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.newfiber.termite.mapper.DeviceMonitoringDataRealtimeMapper">

    <!-- 通用查询映射结果 -->
    <resultMap type="com.newfiber.termite.domain.DeviceMonitoringDataRealtime" id="DeviceMonitoringDataRealtimeResult">
        <result property="id" column="id"/>
        <result property="sn" column="sn"/>
        <result property="date" column="date"/>
        <result property="yesnoant" column="yesnoant"/>
        <result property="rtpitcu" column="rtpitcu"/>
        <result property="idenpitcu" column="idenpitcu"/>
        <result property="idencolle" column="idencolle"/>
        <result property="antNumber" column="ant_number"/>
        <result property="otherAntNumber" column="other_ant_number"/>
        <result property="smallAntNumber" column="small_ant_number"/>
        <result property="antQuiltPercent" column="ant_quilt_percent"/>
        <result property="druing" column="druing"/>
        <result property="druingDatetime" column="druing_datetime"/>
        <result property="heating" column="heating"/>
        <result property="heatingDatetime" column="heating_datetime"/>
        <result property="uptime" column="uptime"/>
        <result property="projectCode" column="project_code"/>
    </resultMap>

    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
        t.id
    	, t.sn
    	, t.date
    	, t.yesnoant
    	, t.rtpitcu
    	, t.idenpitcu
    	, t.idencolle
        , t.ant_number
        , t.other_ant_number
        , t.small_ant_number
        , t.ant_quilt_percent
    	, t.druing
    	, t.druing_datetime
    	, t.heating
    	, t.heating_datetime
    	, t.uptime
        , tpi.project_code
	</sql>

    <sql id="Where_Condition">
        <if test="request.sn != null and request.sn != ''">
            and t.sn = #{request.sn}
        </if>
        <if test="request.date != null and request.date != ''">
            and t.date = #{request.date}
        </if>
        <if test="request.yesnoant != null and request.yesnoant != ''">
            and t.yesnoant = #{request.yesnoant}
        </if>

        <if test="request.userId != null and request.userId != ''">
            and pu.user_id = #{request.userId}
        </if>
        <if test="request.projectCodeList != null and !request.projectCodeList.isEmpty()">
            and tpi.project_code in
            <foreach item="projectCode" collection="request.projectCodeList" open="(" separator="," close=")">
                #{projectCode}
            </foreach>
        </if>

        <if test="request.projectCodeNotInList != null and !request.projectCodeNotInList.isEmpty()">
            and tpi.project_code not in
            <foreach item="projectCode" collection="request.projectCodeNotInList" open="(" separator="," close=")">
                #{projectCode}
            </foreach>
        </if>
    </sql>

    <sql id="Join_Table">
        left join ter_device_info di on t.sn = di.sn
        left join ter_project_info tpi on di.project_code = tpi.project_code

        <if test="request.userId != null and request.userId != ''">
            left join ter_project_user pu on tpi.project_code = pu.project_code
        </if>
    </sql>

    <select id="selectByCondition" resultMap="DeviceMonitoringDataRealtimeResult">
        select
        <include refid="Base_Column_List"/>
        from ter_device_monitoring_data_realtime t
        <include refid="Join_Table"/>
        where t.del_flag = '0'
        <include refid="Where_Condition"/>
        order by t.${request.orderBy}
    </select>

    <select id="selectOneById" resultMap="DeviceMonitoringDataRealtimeResult">
        select
        <include refid="Base_Column_List"/>
        from ter_device_monitoring_data_realtime t
        <include refid="Join_Table"/>
        where t.id = #{id} and t.del_flag = '0'
    </select>

    <delete id="deleteBySn">
        delete from ter_device_monitoring_data_realtime where sn = #{sn}
    </delete>

    <select id="statistics" resultType="com.newfiber.termite.domain.response.statistic.MonitoringWarnResponseStatistics">
        select tpi.project_name, di.project_code as projectCode, count(1) as warnCount
        from ter_device_monitoring_data_realtime t
        <include refid="Join_Table"/>
        where t.del_flag = '0'
        <include refid="Where_Condition"/>
        and (di.project_code != '' or di.project_code != null) and di.del_flag = '0'
        group by di.project_code, tpi.project_name
    </select>

</mapper>