Newer
Older
newfiber-termite / newfiber-termites / newfiber-termites-dataup / src / main / resources / mapper / termite / DeviceInfoMapper.xml
@xiongkai xiongkai 6 days ago 8 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.DeviceInfoMapper">

    <!-- 通用查询映射结果 -->
    <resultMap type="com.newfiber.termite.domain.DeviceInfo" id="DeviceInfoResult">
        <result property="id" column="id"/>
        <result property="category" column="category"/>
        <result property="projectCode" column="project_code"/>
        <result property="sn" column="sn"/>
        <result property="deviceType" column="device_type"/>
        <result property="locationType" column="location_type"/>
        <result property="location" column="location"/>
        <result property="initialpictu" column="initialpictu"/>
        <result property="extendConfig" column="extend_config"/>
        <result property="lonandlat" column="lonandlat"/>
        <result property="geometryNumber" column="geometry_number"/>
        <result property="delFlag" column="del_flag"/>
        <result property="lastPicTime" column="last_pic_time"/>
        <result property="lastHeatTime" column="last_heat_time"/>
        <result property="lastMedicateTime" column="last_medicate_time"/>
        <result property="firstWarnDatetime" column="first_warn_datetime"/>
        <result property="druging" column="druging"/>
        <result property="software" column="software"/>
        <result property="hardware" column="hardware"/>
        <result property="voltage" column="voltage"/>
        <result property="temperature" column="temperature"/>
        <result property="rssi" column="rssi"/>
        <result property="ap" column="ap"/>
        <result property="camera" column="camera"/>
        <result property="uploadCycleHour" column="upload_cycle_hour"/>
        <result property="lastSyncTime" column="last_sync_time"/>
        <result property="autoHeat" column="auto_heat"/>
        <result property="oemConfigApi" column="oem_config_api"/>

        <result property="lteManufactor" column="lte_manufactor"/>
        <result property="lteModel" column="lte_model"/>
        <result property="lteFirmware" column="lte_firmware"/>
        <result property="lteImei" column="lte_imei"/>
        <result property="lteIccid" column="lte_iccid"/>
        <result property="lteCpos" column="lte_cpos"/>
        <result property="lteCsq" column="lte_csq"/>

        <result property="yesnoant" column="yesnoant" />
        <result property="uploadApi" column="upload_api"/>
        <result property="projectName" column="project_name"/>

        <result property="druingDatetime" column="druing_datetime"/>
        <result property="heating" column="heating"/>
        <result property="heatingDatetime" column="heating_datetime"/>
        <result property="continueCaptureFlag" column="continueCaptureFlag"/>
    </resultMap>

    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
        t.id
    	, t.category
    	, t.project_code
    	, t.sn
        , t.device_type
        , t.location_type
    	, t.location
    	, t.initialpictu
        , t.extend_config
    	, t.lonandlat
        , t.geometry_number
    	, t.del_flag
    	, t.last_pic_time
        , t.last_heat_time
        , t.last_medicate_time
    	, t.first_warn_datetime
        , t.druging
        , t.software
        , t.hardware
        , t.voltage
        , t.temperature
        , t.rssi
        , t.ap
        , t.camera
        , t.upload_cycle_hour
        , t.last_sync_time
        , t.auto_heat
        , t.lte_manufactor
        , t.lte_model
        , t.lte_firmware
        , t.lte_imei
        , t.lte_iccid
        , t.lte_cpos
        , t.lte_csq

        , tpi.oem_config_api
        , tpi.upload_api
        , tpi.project_name

        , tr.druing_datetime
        , tr.heating
        , tr.heating_datetime
        , case when tr.continue_capture_count > 0 then 'true' else 'false' end as continueCaptureFlag
	</sql>

    <sql id="Where_Condition">
        <if test="request.category != null and request.category != ''">
            and t.category = #{request.category}
        </if>
        <if test="request.projectCode != null and request.projectCode != ''">
            and t.project_code = #{request.projectCode}
        </if>
        <if test="request.sn != null and request.sn != ''">
            and t.sn = #{request.sn}
        </if>
        <if test="request.warnFlag != null and request.warnFlag != ''">
            and t.first_warn_datetime is not null
        </if>
        <if test="request.autoHeat != null and request.autoHeat != ''">
            and t.auto_heat = #{request.autoHeat}
        </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 t.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 t.project_code not in
            <foreach item="projectCode" collection="request.projectCodeNotInList" open="(" separator="," close=")">
                #{projectCode}
            </foreach>
        </if>
    </sql>

    <sql id="Join_Table">
        left join ter_project_info tpi on t.project_code = tpi.project_code
        left join ter_device_monitoring_data_realtime tr on t.sn = tr.sn
        <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="DeviceInfoResult">
        select
        <include refid="Base_Column_List"/>
        from ter_device_info t
        <include refid="Join_Table"/>
        where t.del_flag = '0'
        <include refid="Where_Condition"/>
        order by t.${request.orderBy}
    </select>

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

    <resultMap type="com.newfiber.termite.domain.response.statistic.ProjectStatisticDetail" id="statisticResult">
        <result property="projectCode" column="project_code"/>
        <result property="projectName" column="project_name"/>
        <result property="firstWarnDatetime" column="first_warn_datetime"/>
        <result property="deviceCount" column="deviceCount"/>
    </resultMap>
    <select id="statistic" resultMap="statisticResult">
        select tpi.project_name, t.project_code, count(1) as deviceCount, min(first_warn_datetime) as first_warn_datetime
        from ter_device_info t
        <include refid="Join_Table"/>
        where t.del_flag = '0'
        <include refid="Where_Condition"/>
        and (t.project_code != '' or t.project_code != null)
        group by t.project_code, tpi.project_name
    </select>

    <update id="deviceAntSchedule">
        update ter_device_info set yesnoant = 2;
        update ter_device_info set yesnoant = 1 where sn in (select sn from ter_device_monitoring_data_realtime where yesnoant = 1)
        and category = 'project' and project_code != 'test';
    </update>

        <select id="deviceStatusStatistic" resultType="com.newfiber.termite.domain.response.statistic.DeviceStatusStatistic">
        select t.project_code,
            <![CDATA[
                (select count(1) from ter_device_info sub left join ter_device_monitoring_data_realtime r on sub.sn = r.sn where sub.project_code = t.project_code and ((TIMESTAMPDIFF(minute, r.uptime, now()) > 1440) or r.uptime is null) and sub.del_flag = '0') as offlineCount,
                (select count(1) from ter_device_info sub left join ter_device_monitoring_data_realtime r on sub.sn = r.sn where sub.project_code = t.project_code and (TIMESTAMPDIFF(minute, r.uptime, now()) <= 1440) and sub.del_flag = '0') as onlineCount
            ]]>
        FROM ter_device_info t
        where t.del_flag = '0'
        <include refid="Where_Condition"/>
        group by t.project_code
    </select>
</mapper>