<?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.zehong.system.mapper.THiddenTroubleMapper">
    
    <resultMap type="THiddenTrouble" id="THiddenTroubleResult">
        <result property="troubleId"    column="trouble_id"    />
        <result property="troubleName"    column="trouble_name"    />
        <result property="troubleType"    column="trouble_type"    />
        <result property="deviceId"    column="device_id"    />
        <result property="troubleLevel"    column="trouble_level"    />
        <result property="orderId"    column="order_id"    />
        <result property="longitude"    column="longitude"    />
        <result property="deviceType"    column="device_type"    />
        <result property="latitude"    column="latitude"    />
        <result property="isDel"    column="is_del"    />
        <result property="dealStatus"    column="deal_status"    />
        <result property="updateTime"    column="update_time"    />
        <result property="address"    column="address"    />
        <result property="createTime"    column="create_time"    />
        <result property="remarks"    column="remarks"    />
        <result property="pictureUrl"    column="picture_url"    />
        <result property="reportMan"    column="report_man"    />
    </resultMap>

    <sql id="selectTHiddenTroubleVo">
        select trouble_id, trouble_name, trouble_type, device_id, trouble_level, order_id, longitude, device_type, latitude, is_del, deal_status, update_time, address, create_time, remarks, picture_url, report_man from t_hidden_trouble
    </sql>

    <select id="selectTHiddenTroubleList" parameterType="HiddenTroubleForm" resultMap="THiddenTroubleResult">
        <include refid="selectTHiddenTroubleVo"/>
        <where>
            and is_del = '0'
            <if test="troubleName != null  and troubleName != ''"> and trouble_name like concat('%', #{troubleName}, '%')</if>
            <if test="troubleType != null  and troubleType != ''"> and trouble_type = #{troubleType}</if>
            <if test="deviceId != null "> and device_id = #{deviceId}</if>
            <if test="troubleLevel != null  and troubleLevel != ''"> and trouble_level = #{troubleLevel}</if>
            <if test="orderId != null  and orderId != ''"> and order_id = #{orderId}</if>
            <if test="longitude != null "> and longitude = #{longitude}</if>
            <if test="deviceType != null  and deviceType != ''"> and device_type = #{deviceType}</if>
            <if test="latitude != null "> and latitude = #{latitude}</if>
            <if test="dealStatus != null  and dealStatus != '' and dealStatus != -2 and dealStatus != -1"> and deal_status = #{dealStatus}</if>
            <if test="dealStatus == -1"> and order_id is null</if>
            <if test="dealStatus == -2"> and order_id is not null and deal_status is null</if>
            <if test="address != null  and address != ''"> and address = #{address}</if>
            <if test="remarks != null  and remarks != ''"> and remarks = #{remarks}</if>
            <if test="pictureUrl != null  and pictureUrl != ''"> and picture_url = #{pictureUrl}</if>
            <if test="reportMan != null "> and report_man = #{reportMan}</if>
            <if test="startCreateTime != null "> and create_time &gt;= #{startCreateTime}</if>
            <if test="endCreateTime != null "> and create_time &lt;= #{endCreateTime}</if>
        </where>
        order by create_time desc
    </select>

    <select id="getMapTHiddenTroubleList" parameterType="String" resultMap="THiddenTroubleResult">
        <include refid="selectTHiddenTroubleVo"/>
        <where> is_del = '0' and (deal_status is null or deal_status = '3')
            <if test="troubleName != null"> and trouble_name like concat('%', #{troubleName}, '%')</if>
        </where>
        order by create_time desc
    </select>
    
    <select id="selectTHiddenTroubleById" parameterType="int" resultMap="THiddenTroubleResult">
        <include refid="selectTHiddenTroubleVo"/>
        where trouble_id = #{troubleId}
    </select>
        
    <insert id="insertTHiddenTrouble" parameterType="THiddenTrouble" useGeneratedKeys="true" keyProperty="troubleId">
        insert into t_hidden_trouble
        <trim prefix="(" suffix=")" suffixOverrides=",">
            <if test="troubleName != null">trouble_name,</if>
            <if test="troubleType != null">trouble_type,</if>
            <if test="deviceId != null">device_id,</if>
            <if test="troubleLevel != null">trouble_level,</if>
            <if test="orderId != null">order_id,</if>
            <if test="longitude != null">longitude,</if>
            <if test="deviceType != null">device_type,</if>
            <if test="latitude != null">latitude,</if>
            <if test="dealStatus != null">deal_status,</if>
            <if test="updateTime != null">update_time,</if>
            <if test="address != null">address,</if>
            <if test="createTime != null">create_time,</if>
            <if test="remarks != null">remarks,</if>
            <if test="pictureUrl != null">picture_url,</if>
            <if test="reportMan != null">report_man,</if>
         </trim>
        <trim prefix="values (" suffix=")" suffixOverrides=",">
            <if test="troubleName != null">#{troubleName},</if>
            <if test="troubleType != null">#{troubleType},</if>
            <if test="deviceId != null">#{deviceId},</if>
            <if test="troubleLevel != null">#{troubleLevel},</if>
            <if test="orderId != null">#{orderId},</if>
            <if test="longitude != null">#{longitude},</if>
            <if test="deviceType != null">#{deviceType},</if>
            <if test="latitude != null">#{latitude},</if>
            <if test="dealStatus != null">#{dealStatus},</if>
            <if test="updateTime != null">#{updateTime},</if>
            <if test="address != null">#{address},</if>
            <if test="createTime != null">#{createTime},</if>
            <if test="remarks != null">#{remarks},</if>
            <if test="pictureUrl != null">#{pictureUrl},</if>
            <if test="reportMan != null">#{reportMan},</if>
         </trim>
    </insert>

    <update id="updateTHiddenTrouble" parameterType="THiddenTrouble">
        update t_hidden_trouble
        <trim prefix="SET" suffixOverrides=",">
            <if test="troubleName != null">trouble_name = #{troubleName},</if>
            <if test="troubleType != null">trouble_type = #{troubleType},</if>
            <if test="deviceId != null">device_id = #{deviceId},</if>
            <if test="troubleLevel != null">trouble_level = #{troubleLevel},</if>
            <if test="orderId != null">order_id = #{orderId},</if>
            <if test="longitude != null">longitude = #{longitude},</if>
            <if test="deviceType != null">device_type = #{deviceType},</if>
            <if test="latitude != null">latitude = #{latitude},</if>
            <if test="isDel != null">is_del = #{isDel},</if>
            <if test="dealStatus != null">deal_status = #{dealStatus},</if>
            <if test="updateTime != null">update_time = #{updateTime},</if>
            <if test="address != null">address = #{address},</if>
            <if test="createTime != null">create_time = #{createTime},</if>
            <if test="remarks != null">remarks = #{remarks},</if>
            <if test="pictureUrl != null">picture_url = #{pictureUrl},</if>
            <if test="reportMan != null">report_man = #{reportMan},</if>
        </trim>
        where trouble_id = #{troubleId}
    </update>

    <delete id="deleteTHiddenTroubleById" parameterType="Long">
        delete from t_hidden_trouble where trouble_id = #{troubleId}
    </delete>

    <delete id="deleteTHiddenTroubleByIds" parameterType="String">
        delete from t_hidden_trouble where trouble_id in 
        <foreach item="troubleId" collection="array" open="(" separator="," close=")">
            #{troubleId}
        </foreach>
    </delete>
</mapper>