<?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>