<?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.TermiteMapper"> <select id="querytermiteData" resultType="com.newfiber.termite.domain.response.TermiteInfoResponse"> SELECT ta.id as deviceId, tb.id, ta.category, ta.sn, ta.location, ta.lonandlat, tb.date, <!--tb.yesnoant,--> case when ta.project_code = 'test' then '2' else ta.yesnoant end as yesnoant, tb.rtpitcu, tb.idenpitcu, tb.idencolle, tb.druing, tb.druing_datetime, tb.heating, tb.heating_datetime, tb.uptime, ta.software, ta.status, case when TIMESTAMPDIFF(minute, tb.uptime, now()) > 1440 then 0 else 1 end as onlineStatus, case when TIMESTAMPDIFF(minute, ta.last_sync_time, now()) > 1440 then 0 else 1 end as syncStatus, case when tb.continue_capture_count > 0 then 'true' else 'false' end as continueCaptureFlag, ta.project_code as projectCode, th.project_name as projectName, ta.first_warn_datetime as firstWarnDatetime, ta.upload_cycle_hour as uploadCycleHour, ta.last_sync_time as lastSyncTime, ta.auto_heat as autoHeat, ta.create_time as createTime FROM `ter_device_info` ta <include refid="Join_Table"/> left join ter_project_info th on ta.project_code =th.project_code and th.del_flag = '0' LEFT JOIN ter_device_monitoring_data_realtime tb ON ta.sn = tb.sn where 1=1 and ta.del_flag = '0' <if test="request.projectName != null and request.projectName != ''"> and th.project_name like concat('%',#{request.projectName},'%') </if> <if test="request.sn != null and request.sn != ''"> and ta.sn like concat('%',#{request.sn},'%') </if> <if test="request.uptime != null and request.uptime != ''"> and tb.uptime like concat('%',#{request.uptime},'%') </if> <if test="request.location != null and request.location != ''"> and ta.location like concat('%',#{request.location},'%') </if> <if test="request.yesnoant != null and request.yesnoant != ''"> and (ta.project_code != 'test' and tb.yesnoant =#{request.yesnoant}) </if> <if test="request.idencolle != null and request.idencolle != ''"> and tb.idencolle =#{request.idencolle} </if> <if test="request.druing != null and request.druing != ''"> and tb.druing =#{request.druing} </if> <if test="request.projectCode != null and request.projectCode != ''"> and ta.project_code =#{request.projectCode} </if> <if test="request.category != null and request.category != ''"> and ta.category =#{request.category} </if> <if test="request.projectCodeList != null and request.projectCodeList.size > 0"> and th.project_code in <foreach collection="request.projectCodeList" item="projectCode" index="index" open="(" close=")" separator=","> #{projectCode} </foreach> </if> <if test="request.onlineStatus == '1' and request.onlineStatus != null and request.onlineStatus != ''"> <![CDATA[ and TIMESTAMPDIFF(minute, tb.uptime, now()) < 1440 ]]> </if> <if test="request.onlineStatus == '0' and request.onlineStatus != null and request.onlineStatus != ''"> <![CDATA[ and TIMESTAMPDIFF(minute, tb.uptime, now()) > 1440 ]]> </if> <if test="request.userId != null and request.userId != '' and request.userId != 1"> and pu.user_id = #{request.userId} </if> <choose> <when test="request.orderBy != null and request.orderBy != ''"> order by ${request.orderBy} </when> <otherwise> order by ta.yesnoant asc, ta.last_pic_time desc </otherwise> </choose> </select> <sql id="Join_Table"> <if test="request.userId != null and request.userId != '' and request.userId != 1"> left join ter_project_user pu on ta.project_code = pu.project_code </if> </sql> <update id="updateMonitorDevice"> UPDATE `ter_device_info` SET `project_code` = #{request.projectCode}, `location_type` = #{request.locationType}, `location` = #{request.location}, `lonandlat` = #{request.lonandlat}, `sn` = #{request.sn} WHERE `id` =#{request.id}; </update> <select id="queryhistoryData" resultType="com.newfiber.termite.domain.response.TermiteInfoResponse"> SELECT ta.id, ta.sn, ta.date, ta.yesnoant, ta.rtpitcu, ta.idenpitcu, ta.idencolle, ta.druing, ta.uptime, tb.location FROM ter_device_monitoring_data ta left join ter_device_info tb on ta.sn=tb.sn where ta.sn=#{request.sn} <if test="request.yesnoant != null and request.yesnoant != ''"> and ta.yesnoant =#{request.yesnoant} </if> <if test="request.idencolle != null and request.idencolle != ''"> and ta.idencolle =#{request.idencolle} </if> <if test="request.druing != null and request.druing != ''"> and ta.druing =#{request.druing} </if> <if test="request.category != null and request.category != ''"> and tb.category = #{request.category} </if> <if test="request.starttime != null and request.starttime != ''"> and ta.uptime > #{request.starttime} </if> <if test="request.projectCode != null and request.projectCode != ''"> and tb.project_code = #{request.projectCode} </if> <if test="request.endtime != null and request.endtime != ''"> and ta.uptime < #{request.endtime} </if> ORDER BY date desc </select> <select id="querynewphoto" resultType="java.lang.String"> select rtpitcu from ter_device_monitoring_data where sn=#{sn} order by uptime desc limit 1 </select> <update id="updateModlefirstData"> UPDATE `ter_device_info` SET `initialpictu` = #{newphoto} WHERE `sn` = #{sn} </update> <resultMap type="com.newfiber.termite.domain.response.DataUpResponse" id="DataUpResponseResult"> <result property="druing" column="druing"/> <result property="heating" column="heating"/> </resultMap> <select id="queryDataUpResponse" resultMap="DataUpResponseResult"> select druing, heating from ter_device_monitoring_data where sn=#{sn} order by uptime desc limit 1 </select> <select id="queryUnitdata" resultType="com.newfiber.termite.domain.dto.UnitInfoDto"> SELECT construction_unit, people, telephone FROM `ter_unit_info` where is_choose = 1 </select> </mapper>