<?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.TVehicleInfoMapper">
    
    <resultMap type="TVehicleInfo" id="TVehicleInfoResult">
        <result property="vehicleId"    column="vehicle_id"    />
        <result property="carNum"    column="car_num"    />
        <result property="brandModel"    column="brand_model"    />
        <result property="vehicleType"    column="vehicle_type"    />
        <result property="vehicleLoad"    column="vehicle_load"    />
        <result property="vehicleSize"    column="vehicle_size"    />
        <result property="vehicleLimt"    column="vehicle_limt"    />
        <result property="vehicleInspect"    column="vehicle_inspect"    />
        <result property="beyondEnterpriseId"    column="beyond_enterprise_id"    />
        <result property="personLiable"    column="person_liable"    />
        <result property="phone"    column="phone"    />
        <result property="isDel"    column="is_del"    />
        <result property="remarks"    column="remarks"    />
    </resultMap>

    <sql id="selectTVehicleInfoVo">
        select vehicle_id, car_num, brand_model, vehicle_type, vehicle_load, vehicle_size, vehicle_limt, vehicle_inspect, beyond_enterprise_id, person_liable, phone, is_del, remarks from t_vehicle_info
    </sql>

    <select id="selectTVehicleInfoList" parameterType="TVehicleInfo" resultMap="TVehicleInfoResult">
        <include refid="selectTVehicleInfoVo"/>
        <where>  
            <if test="carNum != null  and carNum != ''"> and car_num like concat('%', #{carNum}, '%') </if>
            <if test="brandModel != null  and brandModel != ''"> and brand_model = #{brandModel}</if>
            <if test="vehicleType != null  and vehicleType != ''"> and vehicle_type = #{vehicleType}</if>
            <if test="vehicleLoad != null  and vehicleLoad != ''"> and vehicle_load = #{vehicleLoad}</if>
            <if test="vehicleSize != null  and vehicleSize != ''"> and vehicle_size = #{vehicleSize}</if>
            <if test="vehicleLimt != null  and vehicleLimt != ''"> and vehicle_limt = #{vehicleLimt}</if>
            <if test="vehicleInspect != null  and vehicleInspect != ''"> and vehicle_inspect = #{vehicleInspect}</if>
            <if test="beyondEnterpriseId != null  and beyondEnterpriseId != ''"> and beyond_enterprise_id = #{beyondEnterpriseId}</if>
            <if test="personLiable != null  and personLiable != ''"> and person_liable = #{personLiable}</if>
            <if test="phone != null  and phone != ''"> and phone = #{phone}</if>
            <if test="isDel != null  and isDel != ''"> and is_del = #{isDel}</if>
            <if test="remarks != null  and remarks != ''"> and remarks = #{remarks}</if>
        </where>
    </select>
    
    <select id="selectTVehicleInfoById" parameterType="Long" resultMap="TVehicleInfoResult">
        <include refid="selectTVehicleInfoVo"/>
        where vehicle_id = #{vehicleId}
    </select>
        
    <insert id="insertTVehicleInfo" parameterType="TVehicleInfo" useGeneratedKeys="true" keyProperty="vehicleId">
        insert into t_vehicle_info
        <trim prefix="(" suffix=")" suffixOverrides=",">
            <if test="carNum != null">car_num,</if>
            <if test="brandModel != null">brand_model,</if>
            <if test="vehicleType != null">vehicle_type,</if>
            <if test="vehicleLoad != null">vehicle_load,</if>
            <if test="vehicleSize != null">vehicle_size,</if>
            <if test="vehicleLimt != null">vehicle_limt,</if>
            <if test="vehicleInspect != null">vehicle_inspect,</if>
            <if test="beyondEnterpriseId != null">beyond_enterprise_id,</if>
            <if test="personLiable != null">person_liable,</if>
            <if test="phone != null">phone,</if>
            <if test="isDel != null">is_del,</if>
            <if test="remarks != null">remarks,</if>
         </trim>
        <trim prefix="values (" suffix=")" suffixOverrides=",">
            <if test="carNum != null">#{carNum},</if>
            <if test="brandModel != null">#{brandModel},</if>
            <if test="vehicleType != null">#{vehicleType},</if>
            <if test="vehicleLoad != null">#{vehicleLoad},</if>
            <if test="vehicleSize != null">#{vehicleSize},</if>
            <if test="vehicleLimt != null">#{vehicleLimt},</if>
            <if test="vehicleInspect != null">#{vehicleInspect},</if>
            <if test="beyondEnterpriseId != null">#{beyondEnterpriseId},</if>
            <if test="personLiable != null">#{personLiable},</if>
            <if test="phone != null">#{phone},</if>
            <if test="isDel != null">#{isDel},</if>
            <if test="remarks != null">#{remarks},</if>
         </trim>
    </insert>

    <update id="updateTVehicleInfo" parameterType="TVehicleInfo">
        update t_vehicle_info
        <trim prefix="SET" suffixOverrides=",">
            <if test="carNum != null">car_num = #{carNum},</if>
            <if test="brandModel != null">brand_model = #{brandModel},</if>
            <if test="vehicleType != null">vehicle_type = #{vehicleType},</if>
            <if test="vehicleLoad != null">vehicle_load = #{vehicleLoad},</if>
            <if test="vehicleSize != null">vehicle_size = #{vehicleSize},</if>
            <if test="vehicleLimt != null">vehicle_limt = #{vehicleLimt},</if>
            <if test="vehicleInspect != null">vehicle_inspect = #{vehicleInspect},</if>
            <if test="beyondEnterpriseId != null">beyond_enterprise_id = #{beyondEnterpriseId},</if>
            <if test="personLiable != null">person_liable = #{personLiable},</if>
            <if test="phone != null">phone = #{phone},</if>
            <if test="isDel != null">is_del = #{isDel},</if>
            <if test="remarks != null">remarks = #{remarks},</if>
        </trim>
        where vehicle_id = #{vehicleId}
    </update>

    <delete id="deleteTVehicleInfoById" parameterType="Long">
        delete from t_vehicle_info where vehicle_id = #{vehicleId}
    </delete>

    <delete id="deleteTVehicleInfoByIds" parameterType="String">
        delete from t_vehicle_info where vehicle_id in 
        <foreach item="vehicleId" collection="array" open="(" separator="," close=")">
            #{vehicleId}
        </foreach>
    </delete>
</mapper>