<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"mybatis-3-mapper.dtd">
<mapper namespace="com.mortals.xhx.module.hik.face.dao.ibatis.FacePlanDaoImpl">

    <!-- 字段和属性映射 -->
    <resultMap type="FacePlanEntity" id="FacePlanEntity-Map">
            <id  property="id" column="id" />
            <result property="indexCode" column="indexCode" />
            <result property="name" column="name" />
            <result property="faceGroupIndexCodes" column="faceGroupIndexCodes" />
            <result property="cameraIndexCodes" column="cameraIndexCodes" />
            <result property="recognitionResourceIndexCodes" column="recognitionResourceIndexCodes" />
            <result property="recognitionResourceType" column="recognitionResourceType" />
            <result property="recognitionPlanType" column="recognitionPlanType" />
            <result property="status" column="status" />
            <result property="available" column="available" />
            <result property="description" column="description" />
            <result property="startTime" column="startTime" />
            <result property="usingTime" column="usingTime" />
            <result property="threshold" column="threshold" />
            <result property="createTime" column="createTime" />
            <result property="createUserId" column="createUserId" />
            <result property="updateTime" column="updateTime" />
            <result property="updateUserId" column="updateUserId" />
            
    </resultMap>


    <!-- 表所有列 -->
    <sql id="_columns">
        <trim suffixOverrides="," suffix="">
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('id') or colPickMode == 1 and data.containsKey('id')))">
                    a.id,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('indexCode') or colPickMode == 1 and data.containsKey('indexCode')))">
                    a.indexCode,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('name') or colPickMode == 1 and data.containsKey('name')))">
                    a.name,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('faceGroupIndexCodes') or colPickMode == 1 and data.containsKey('faceGroupIndexCodes')))">
                    a.faceGroupIndexCodes,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('cameraIndexCodes') or colPickMode == 1 and data.containsKey('cameraIndexCodes')))">
                    a.cameraIndexCodes,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('recognitionResourceIndexCodes') or colPickMode == 1 and data.containsKey('recognitionResourceIndexCodes')))">
                    a.recognitionResourceIndexCodes,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('recognitionResourceType') or colPickMode == 1 and data.containsKey('recognitionResourceType')))">
                    a.recognitionResourceType,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('recognitionPlanType') or colPickMode == 1 and data.containsKey('recognitionPlanType')))">
                    a.recognitionPlanType,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('status') or colPickMode == 1 and data.containsKey('status')))">
                    a.status,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('available') or colPickMode == 1 and data.containsKey('available')))">
                    a.available,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('description') or colPickMode == 1 and data.containsKey('description')))">
                    a.description,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('startTime') or colPickMode == 1 and data.containsKey('startTime')))">
                    a.startTime,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('usingTime') or colPickMode == 1 and data.containsKey('usingTime')))">
                    a.usingTime,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('threshold') or colPickMode == 1 and data.containsKey('threshold')))">
                    a.threshold,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createTime') or colPickMode == 1 and data.containsKey('createTime')))">
                    a.createTime,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createUserId') or colPickMode == 1 and data.containsKey('createUserId')))">
                    a.createUserId,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('updateTime') or colPickMode == 1 and data.containsKey('updateTime')))">
                    a.updateTime,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('updateUserId') or colPickMode == 1 and data.containsKey('updateUserId')))">
                    a.updateUserId,
                </if>
        </trim>
    </sql>
    <!-- 新增 区分主键自增加还是业务插入 -->
    <insert id="insert" parameterType="FacePlanEntity"  useGeneratedKeys="true" keyProperty="id">
        insert into mortals_xhx_face_plan
        (indexCode,name,faceGroupIndexCodes,cameraIndexCodes,recognitionResourceIndexCodes,recognitionResourceType,recognitionPlanType,status,available,description,startTime,usingTime,threshold,createTime,createUserId,updateTime,updateUserId)
        VALUES
        (#{indexCode},#{name},#{faceGroupIndexCodes},#{cameraIndexCodes},#{recognitionResourceIndexCodes},#{recognitionResourceType},#{recognitionPlanType},#{status},#{available},#{description},#{startTime},#{usingTime},#{threshold},#{createTime},#{createUserId},#{updateTime},#{updateUserId})
    </insert>

    <!-- 批量新增 -->
    <insert id="insertBatch" parameterType="paramDto">
        insert into mortals_xhx_face_plan
        (indexCode,name,faceGroupIndexCodes,cameraIndexCodes,recognitionResourceIndexCodes,recognitionResourceType,recognitionPlanType,status,available,description,startTime,usingTime,threshold,createTime,createUserId,updateTime,updateUserId)
        VALUES
        <foreach collection="data.dataList" item="item" index="index" separator="," >
            (#{item.indexCode},#{item.name},#{item.faceGroupIndexCodes},#{item.cameraIndexCodes},#{item.recognitionResourceIndexCodes},#{item.recognitionResourceType},#{item.recognitionPlanType},#{item.status},#{item.available},#{item.description},#{item.startTime},#{item.usingTime},#{item.threshold},#{item.createTime},#{item.createUserId},#{item.updateTime},#{item.updateUserId})
        </foreach>
    </insert>


    <!-- 根据ParamDto更新 -->
    <update id="update" parameterType="paramDto">
        update mortals_xhx_face_plan as a
        set
        <trim suffixOverrides="," suffix="">
            <if test="(colPickMode==0 and data.containsKey('indexCode')) or (colPickMode==1 and !data.containsKey('indexCode'))">
                a.indexCode=#{data.indexCode},
            </if>
            <if test="(colPickMode==0 and data.containsKey('name')) or (colPickMode==1 and !data.containsKey('name'))">
                a.name=#{data.name},
            </if>
            <if test="(colPickMode==0 and data.containsKey('faceGroupIndexCodes')) or (colPickMode==1 and !data.containsKey('faceGroupIndexCodes'))">
                a.faceGroupIndexCodes=#{data.faceGroupIndexCodes},
            </if>
            <if test="(colPickMode==0 and data.containsKey('cameraIndexCodes')) or (colPickMode==1 and !data.containsKey('cameraIndexCodes'))">
                a.cameraIndexCodes=#{data.cameraIndexCodes},
            </if>
            <if test="(colPickMode==0 and data.containsKey('recognitionResourceIndexCodes')) or (colPickMode==1 and !data.containsKey('recognitionResourceIndexCodes'))">
                a.recognitionResourceIndexCodes=#{data.recognitionResourceIndexCodes},
            </if>
            <if test="(colPickMode==0 and data.containsKey('recognitionResourceType')) or (colPickMode==1 and !data.containsKey('recognitionResourceType'))">
                a.recognitionResourceType=#{data.recognitionResourceType},
            </if>
            <if test="(colPickMode==0 and data.containsKey('recognitionPlanType')) or (colPickMode==1 and !data.containsKey('recognitionPlanType'))">
                a.recognitionPlanType=#{data.recognitionPlanType},
            </if>
            <if test="(colPickMode==0 and data.containsKey('status')) or (colPickMode==1 and !data.containsKey('status'))">
                a.status=#{data.status},
            </if>
            <if test="(colPickMode==0 and data.containsKey('available')) or (colPickMode==1 and !data.containsKey('available'))">
                a.available=#{data.available},
            </if>
            <if test="(colPickMode==0 and data.containsKey('description')) or (colPickMode==1 and !data.containsKey('description'))">
                a.description=#{data.description},
            </if>
            <if test="(colPickMode==0 and data.containsKey('startTime')) or (colPickMode==1 and !data.containsKey('startTime'))">
                a.startTime=#{data.startTime},
            </if>
            <if test="(colPickMode==0 and data.containsKey('usingTime')) or (colPickMode==1 and !data.containsKey('usingTime'))">
                a.usingTime=#{data.usingTime},
            </if>
            <if test="(colPickMode==0 and data.containsKey('usingTimeIncrement')) or (colPickMode==1 and !data.containsKey('usingTimeIncrement'))">
                a.usingTime=ifnull(a.usingTime,0) + #{data.usingTimeIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('threshold')) or (colPickMode==1 and !data.containsKey('threshold'))">
                a.threshold=#{data.threshold},
            </if>
            <if test="(colPickMode==0 and data.containsKey('thresholdIncrement')) or (colPickMode==1 and !data.containsKey('thresholdIncrement'))">
                a.threshold=ifnull(a.threshold,0) + #{data.thresholdIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('createTime')) or (colPickMode==1 and !data.containsKey('createTime'))">
                a.createTime=#{data.createTime},
            </if>
            <if test="(colPickMode==0 and data.containsKey('createUserId')) or (colPickMode==1 and !data.containsKey('createUserId'))">
                a.createUserId=#{data.createUserId},
            </if>
            <if test="(colPickMode==0 and data.containsKey('createUserIdIncrement')) or (colPickMode==1 and !data.containsKey('createUserIdIncrement'))">
                a.createUserId=ifnull(a.createUserId,0) + #{data.createUserIdIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('updateTime')) or (colPickMode==1 and !data.containsKey('updateTime'))">
                a.updateTime=#{data.updateTime},
            </if>
            <if test="(colPickMode==0 and data.containsKey('updateUserId')) or (colPickMode==1 and !data.containsKey('updateUserId'))">
                a.updateUserId=#{data.updateUserId},
            </if>
            <if test="(colPickMode==0 and data.containsKey('updateUserIdIncrement')) or (colPickMode==1 and !data.containsKey('updateUserIdIncrement'))">
                a.updateUserId=ifnull(a.updateUserId,0) + #{data.updateUserIdIncrement},
            </if>
        </trim>
        <trim suffixOverrides="where" suffix="">
            where
            <trim prefixOverrides="and" prefix="">
                <include refid="_condition_"/>
            </trim>
        </trim>
    </update>
    <!-- 批量更新 -->
    <update id="updateBatch" parameterType="paramDto">
        update mortals_xhx_face_plan as a
        <trim prefix="set" suffixOverrides=",">
                <trim prefix="indexCode=(case" suffix="ELSE indexCode end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('indexCode')) or (colPickMode==1 and !item.containsKey('indexCode'))">
                            when a.id=#{item.id} then #{item.indexCode}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="name=(case" suffix="ELSE name end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('name')) or (colPickMode==1 and !item.containsKey('name'))">
                            when a.id=#{item.id} then #{item.name}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="faceGroupIndexCodes=(case" suffix="ELSE faceGroupIndexCodes end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('faceGroupIndexCodes')) or (colPickMode==1 and !item.containsKey('faceGroupIndexCodes'))">
                            when a.id=#{item.id} then #{item.faceGroupIndexCodes}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="cameraIndexCodes=(case" suffix="ELSE cameraIndexCodes end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('cameraIndexCodes')) or (colPickMode==1 and !item.containsKey('cameraIndexCodes'))">
                            when a.id=#{item.id} then #{item.cameraIndexCodes}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="recognitionResourceIndexCodes=(case" suffix="ELSE recognitionResourceIndexCodes end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('recognitionResourceIndexCodes')) or (colPickMode==1 and !item.containsKey('recognitionResourceIndexCodes'))">
                            when a.id=#{item.id} then #{item.recognitionResourceIndexCodes}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="recognitionResourceType=(case" suffix="ELSE recognitionResourceType end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('recognitionResourceType')) or (colPickMode==1 and !item.containsKey('recognitionResourceType'))">
                            when a.id=#{item.id} then #{item.recognitionResourceType}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="recognitionPlanType=(case" suffix="ELSE recognitionPlanType end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('recognitionPlanType')) or (colPickMode==1 and !item.containsKey('recognitionPlanType'))">
                            when a.id=#{item.id} then #{item.recognitionPlanType}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="status=(case" suffix="ELSE status end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('status')) or (colPickMode==1 and !item.containsKey('status'))">
                            when a.id=#{item.id} then #{item.status}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="available=(case" suffix="ELSE available end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('available')) or (colPickMode==1 and !item.containsKey('available'))">
                            when a.id=#{item.id} then #{item.available}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="description=(case" suffix="ELSE description end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('description')) or (colPickMode==1 and !item.containsKey('description'))">
                            when a.id=#{item.id} then #{item.description}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="startTime=(case" suffix="ELSE startTime end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('startTime')) or (colPickMode==1 and !item.containsKey('startTime'))">
                            when a.id=#{item.id} then #{item.startTime}
                        </if>
                    </foreach>
                </trim>
                        <trim prefix="usingTime=(case" suffix="ELSE usingTime end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('usingTime')) or (colPickMode==1 and !item.containsKey('usingTime'))">
                                        when a.id=#{item.id} then #{item.usingTime}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('usingTimeIncrement')) or (colPickMode==1 and !item.containsKey('usingTimeIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.usingTime,0) + #{item.usingTimeIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                        <trim prefix="threshold=(case" suffix="ELSE threshold end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('threshold')) or (colPickMode==1 and !item.containsKey('threshold'))">
                                        when a.id=#{item.id} then #{item.threshold}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('thresholdIncrement')) or (colPickMode==1 and !item.containsKey('thresholdIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.threshold,0) + #{item.thresholdIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                <trim prefix="createTime=(case" suffix="ELSE createTime end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('createTime')) or (colPickMode==1 and !item.containsKey('createTime'))">
                            when a.id=#{item.id} then #{item.createTime}
                        </if>
                    </foreach>
                </trim>
                        <trim prefix="createUserId=(case" suffix="ELSE createUserId end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('createUserId')) or (colPickMode==1 and !item.containsKey('createUserId'))">
                                        when a.id=#{item.id} then #{item.createUserId}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('createUserIdIncrement')) or (colPickMode==1 and !item.containsKey('createUserIdIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.createUserId,0) + #{item.createUserIdIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                <trim prefix="updateTime=(case" suffix="ELSE updateTime end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('updateTime')) or (colPickMode==1 and !item.containsKey('updateTime'))">
                            when a.id=#{item.id} then #{item.updateTime}
                        </if>
                    </foreach>
                </trim>
                        <trim prefix="updateUserId=(case" suffix="ELSE updateUserId end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('updateUserId')) or (colPickMode==1 and !item.containsKey('updateUserId'))">
                                        when a.id=#{item.id} then #{item.updateUserId}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('updateUserIdIncrement')) or (colPickMode==1 and !item.containsKey('updateUserIdIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.updateUserId,0) + #{item.updateUserIdIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
        </trim>
        where id in
        <foreach collection="data.dataList" item="item" index="index" open="(" separator="," close=")">
            #{item.id}
        </foreach>
    </update>
    <!-- 根据主健查询 -->
    <select id="getByKey" parameterType="paramDto" resultMap="FacePlanEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_face_plan as a
        where a.id=#{condition.id}
    </select>
    <!-- 根据主健删除 -->
    <delete id="deleteByKey" parameterType="paramDto">
        delete a.* from mortals_xhx_face_plan as a where a.id=#{condition.id}
    </delete>
    <!-- 根据主健删除一批,针对单一主健有效 -->
    <delete id="deleteByKeys">
        delete from mortals_xhx_face_plan where id in
        <foreach collection="array" item="item" index="index" open="(" separator="," close=")">
            #{item}
        </foreach>
    </delete>
    <!-- 根据主健列表删除一批,针对单一主健有效 -->
    <delete id="deleteByKeyList">
        delete from mortals_xhx_face_plan where id in
        <foreach collection="list" item="item" index="index" open="(" separator="," close=")">
            #{item}
        </foreach>
    </delete>

    <!-- 根据对象列表删除一批,针对单一主健有效 -->
    <delete id="deleteByEntityList">
        delete from mortals_xhx_face_plan where id in
        <foreach collection="list" item="item" index="index" open="(" separator="," close=")">
            #{item.id}
        </foreach>
    </delete>
    <!-- 根据paramDto删除一批 -->
    <delete id="deleteByMap" parameterType="paramDto">
        delete a.* from mortals_xhx_face_plan as a
        <trim suffixOverrides="where" suffix="">
            where
            <trim prefixOverrides="and" prefix="">
                <include refid="_condition_"/>
            </trim>
        </trim>
    </delete>
    <!-- 获取列表 -->
    <select id="getList" parameterType="paramDto" resultMap="FacePlanEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_face_plan as a
        <trim suffixOverrides="where" suffix="">
            where
            <trim prefixOverrides="and" prefix="">
                <include refid="_condition_"/>
            </trim>
        </trim>
        <include refid="_orderCols_"/>
    </select>



    <!-- 获取 -->
    <select id="getListCount" parameterType="paramDto" resultType="int">
        select count(1)
        from mortals_xhx_face_plan as a
        <trim suffixOverrides="where" suffix="">
            where
            <trim prefixOverrides="and" prefix="">
                <include refid="_condition_"/>
            </trim>
        </trim>
    </select>
    <!-- 条件映射 -->
    <sql id="_condition_">
        <if test="condition != null and !condition.isEmpty()">
            <!-- 条件映射-普通条件 -->
            <include refid="_condition_param_">
                <property name="_conditionParam_" value="condition"/>
                <property name="_conditionType_" value="and"/>
            </include>
            <!-- 条件映射-集合之间使用AND,集合中元素使用OR-(list[0].1 or list[0].2) and (list[1].3 or list[1].4) -->
            <if test="condition.containsKey('andConditionList') and !condition.andConditionList.isEmpty()">
                and
                <foreach collection="condition.andConditionList" open="(" close=")" index="index" item="andCondition" separator=" and ">
                    <trim prefixOverrides="or" prefix="(" suffix=")">
                        <include refid="_condition_param_">
                            <property name="_conditionParam_" value="andCondition"/>
                            <property name="_conditionType_" value="or"/>
                        </include>
                    </trim>
                </foreach>
            </if>
            <!-- 条件映射-集合之间使用OR,集合中元素使用AND-(list[0].1 and list[0].2) or (list[1].3 and list[1].4) -->
            <if test="condition.containsKey('orConditionList') and !condition.orConditionList.isEmpty()">
                and
                <foreach collection="condition.orConditionList" open="(" close=")" index="index" item="orCondition" separator=" or ">
                    <trim prefixOverrides="and" prefix="(" suffix=")">
                        <include refid="_condition_param_">
                            <property name="_conditionParam_" value="orCondition"/>
                            <property name="_conditionType_" value="and"/>
                        </include>
                    </trim>
                </foreach>
            </if>
        </if>
    </sql>
    <!-- 条件映射-代参数 -->
    <sql id="_condition_param_">
        <bind name="conditionParamRef" value="${_conditionParam_}"/>
        <if test="conditionParamRef.containsKey('id')">
            <if test="conditionParamRef.id != null">
                ${_conditionType_} a.id=#{${_conditionParam_}.id}
            </if>
        </if>
            <if test="conditionParamRef.containsKey('id')">
                <if test="conditionParamRef.id != null ">
                    ${_conditionType_} a.id = #{${_conditionParam_}.id}
                </if>
                <if test="conditionParamRef.id == null">
                    ${_conditionType_} a.id is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('idList') and conditionParamRef.idList.size() > 0">
                ${_conditionType_} a.id in
                <foreach collection="conditionParamRef.idList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('idNotList') and conditionParamRef.idNotList.size() > 0">
                ${_conditionType_} a.id not in
                <foreach collection="conditionParamRef.idNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('idStart') and conditionParamRef.idStart != null">
                ${_conditionType_} a.id <![CDATA[ >= ]]> #{${_conditionParam_}.idStart}
            </if>
            <if test="conditionParamRef.containsKey('idEnd') and conditionParamRef.idEnd != null">
                ${_conditionType_} a.id <![CDATA[ <= ]]> #{${_conditionParam_}.idEnd}
            </if>


            <if test="conditionParamRef.containsKey('indexCode')">
                <if test="conditionParamRef.indexCode != null and conditionParamRef.indexCode != ''">
                    ${_conditionType_} a.indexCode like #{${_conditionParam_}.indexCode}
                </if>
                <if test="conditionParamRef.indexCode == null">
                    ${_conditionType_} a.indexCode is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('indexCodeList') and conditionParamRef.indexCodeList.size() > 0">
                ${_conditionType_} a.indexCode in
                <foreach collection="conditionParamRef.indexCodeList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('indexCodeNotList') and conditionParamRef.indexCodeNotList.size() > 0">
                ${_conditionType_} a.indexCode not in
                <foreach collection="conditionParamRef.indexCodeNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('name')">
                <if test="conditionParamRef.name != null and conditionParamRef.name != ''">
                    ${_conditionType_} a.name like #{${_conditionParam_}.name}
                </if>
                <if test="conditionParamRef.name == null">
                    ${_conditionType_} a.name is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('nameList') and conditionParamRef.nameList.size() > 0">
                ${_conditionType_} a.name in
                <foreach collection="conditionParamRef.nameList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('nameNotList') and conditionParamRef.nameNotList.size() > 0">
                ${_conditionType_} a.name not in
                <foreach collection="conditionParamRef.nameNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('faceGroupIndexCodes')">
                <if test="conditionParamRef.faceGroupIndexCodes != null and conditionParamRef.faceGroupIndexCodes != ''">
                    ${_conditionType_} a.faceGroupIndexCodes like #{${_conditionParam_}.faceGroupIndexCodes}
                </if>
                <if test="conditionParamRef.faceGroupIndexCodes == null">
                    ${_conditionType_} a.faceGroupIndexCodes is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('faceGroupIndexCodesList') and conditionParamRef.faceGroupIndexCodesList.size() > 0">
                ${_conditionType_} a.faceGroupIndexCodes in
                <foreach collection="conditionParamRef.faceGroupIndexCodesList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('faceGroupIndexCodesNotList') and conditionParamRef.faceGroupIndexCodesNotList.size() > 0">
                ${_conditionType_} a.faceGroupIndexCodes not in
                <foreach collection="conditionParamRef.faceGroupIndexCodesNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('cameraIndexCodes')">
                <if test="conditionParamRef.cameraIndexCodes != null and conditionParamRef.cameraIndexCodes != ''">
                    ${_conditionType_} a.cameraIndexCodes like #{${_conditionParam_}.cameraIndexCodes}
                </if>
                <if test="conditionParamRef.cameraIndexCodes == null">
                    ${_conditionType_} a.cameraIndexCodes is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('cameraIndexCodesList') and conditionParamRef.cameraIndexCodesList.size() > 0">
                ${_conditionType_} a.cameraIndexCodes in
                <foreach collection="conditionParamRef.cameraIndexCodesList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('cameraIndexCodesNotList') and conditionParamRef.cameraIndexCodesNotList.size() > 0">
                ${_conditionType_} a.cameraIndexCodes not in
                <foreach collection="conditionParamRef.cameraIndexCodesNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('recognitionResourceIndexCodes')">
                <if test="conditionParamRef.recognitionResourceIndexCodes != null and conditionParamRef.recognitionResourceIndexCodes != ''">
                    ${_conditionType_} a.recognitionResourceIndexCodes like #{${_conditionParam_}.recognitionResourceIndexCodes}
                </if>
                <if test="conditionParamRef.recognitionResourceIndexCodes == null">
                    ${_conditionType_} a.recognitionResourceIndexCodes is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('recognitionResourceIndexCodesList') and conditionParamRef.recognitionResourceIndexCodesList.size() > 0">
                ${_conditionType_} a.recognitionResourceIndexCodes in
                <foreach collection="conditionParamRef.recognitionResourceIndexCodesList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('recognitionResourceIndexCodesNotList') and conditionParamRef.recognitionResourceIndexCodesNotList.size() > 0">
                ${_conditionType_} a.recognitionResourceIndexCodes not in
                <foreach collection="conditionParamRef.recognitionResourceIndexCodesNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('recognitionResourceType')">
                <if test="conditionParamRef.recognitionResourceType != null and conditionParamRef.recognitionResourceType != ''">
                    ${_conditionType_} a.recognitionResourceType like #{${_conditionParam_}.recognitionResourceType}
                </if>
                <if test="conditionParamRef.recognitionResourceType == null">
                    ${_conditionType_} a.recognitionResourceType is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('recognitionResourceTypeList') and conditionParamRef.recognitionResourceTypeList.size() > 0">
                ${_conditionType_} a.recognitionResourceType in
                <foreach collection="conditionParamRef.recognitionResourceTypeList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('recognitionResourceTypeNotList') and conditionParamRef.recognitionResourceTypeNotList.size() > 0">
                ${_conditionType_} a.recognitionResourceType not in
                <foreach collection="conditionParamRef.recognitionResourceTypeNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('recognitionPlanType')">
                <if test="conditionParamRef.recognitionPlanType != null and conditionParamRef.recognitionPlanType != ''">
                    ${_conditionType_} a.recognitionPlanType like #{${_conditionParam_}.recognitionPlanType}
                </if>
                <if test="conditionParamRef.recognitionPlanType == null">
                    ${_conditionType_} a.recognitionPlanType is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('recognitionPlanTypeList') and conditionParamRef.recognitionPlanTypeList.size() > 0">
                ${_conditionType_} a.recognitionPlanType in
                <foreach collection="conditionParamRef.recognitionPlanTypeList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('recognitionPlanTypeNotList') and conditionParamRef.recognitionPlanTypeNotList.size() > 0">
                ${_conditionType_} a.recognitionPlanType not in
                <foreach collection="conditionParamRef.recognitionPlanTypeNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('status')">
                <if test="conditionParamRef.status != null and conditionParamRef.status != ''">
                    ${_conditionType_} a.status like #{${_conditionParam_}.status}
                </if>
                <if test="conditionParamRef.status == null">
                    ${_conditionType_} a.status is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('statusList') and conditionParamRef.statusList.size() > 0">
                ${_conditionType_} a.status in
                <foreach collection="conditionParamRef.statusList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('statusNotList') and conditionParamRef.statusNotList.size() > 0">
                ${_conditionType_} a.status not in
                <foreach collection="conditionParamRef.statusNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('available')">
                <if test="conditionParamRef.available != null and conditionParamRef.available != ''">
                    ${_conditionType_} a.available like #{${_conditionParam_}.available}
                </if>
                <if test="conditionParamRef.available == null">
                    ${_conditionType_} a.available is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('availableList') and conditionParamRef.availableList.size() > 0">
                ${_conditionType_} a.available in
                <foreach collection="conditionParamRef.availableList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('availableNotList') and conditionParamRef.availableNotList.size() > 0">
                ${_conditionType_} a.available not in
                <foreach collection="conditionParamRef.availableNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('description')">
                <if test="conditionParamRef.description != null and conditionParamRef.description != ''">
                    ${_conditionType_} a.description like #{${_conditionParam_}.description}
                </if>
                <if test="conditionParamRef.description == null">
                    ${_conditionType_} a.description is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('descriptionList') and conditionParamRef.descriptionList.size() > 0">
                ${_conditionType_} a.description in
                <foreach collection="conditionParamRef.descriptionList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('descriptionNotList') and conditionParamRef.descriptionNotList.size() > 0">
                ${_conditionType_} a.description not in
                <foreach collection="conditionParamRef.descriptionNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>

            <if test="conditionParamRef.containsKey('startTime')">
                <if test="conditionParamRef.startTime != null ">
                    ${_conditionType_} a.startTime = #{${_conditionParam_}.startTime}
                </if>
                <if test="conditionParamRef.startTime == null">
                    ${_conditionType_} a.startTime is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('startTimeStart') and conditionParamRef.startTimeStart != null and conditionParamRef.startTimeStart!=''">
                ${_conditionType_} a.startTime <![CDATA[ >= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.startTimeStart},' 00:00:00'),19),'%Y-%m-%d %k:%i:%s')
            </if>
            <if test="conditionParamRef.containsKey('startTimeEnd') and conditionParamRef.startTimeEnd != null and conditionParamRef.startTimeEnd!=''">
                ${_conditionType_} a.startTime <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.startTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s')
            </if>
            <if test="conditionParamRef.containsKey('usingTime')">
                <if test="conditionParamRef.usingTime != null ">
                    ${_conditionType_} a.usingTime = #{${_conditionParam_}.usingTime}
                </if>
                <if test="conditionParamRef.usingTime == null">
                    ${_conditionType_} a.usingTime is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('usingTimeList') and conditionParamRef.usingTimeList.size() > 0">
                ${_conditionType_} a.usingTime in
                <foreach collection="conditionParamRef.usingTimeList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('usingTimeNotList') and conditionParamRef.usingTimeNotList.size() > 0">
                ${_conditionType_} a.usingTime not in
                <foreach collection="conditionParamRef.usingTimeNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('usingTimeStart') and conditionParamRef.usingTimeStart != null">
                ${_conditionType_} a.usingTime <![CDATA[ >= ]]> #{${_conditionParam_}.usingTimeStart}
            </if>
            <if test="conditionParamRef.containsKey('usingTimeEnd') and conditionParamRef.usingTimeEnd != null">
                ${_conditionType_} a.usingTime <![CDATA[ <= ]]> #{${_conditionParam_}.usingTimeEnd}
            </if>

            <if test="conditionParamRef.containsKey('threshold')">
                <if test="conditionParamRef.threshold != null ">
                    ${_conditionType_} a.threshold = #{${_conditionParam_}.threshold}
                </if>
                <if test="conditionParamRef.threshold == null">
                    ${_conditionType_} a.threshold is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('thresholdList') and conditionParamRef.thresholdList.size() > 0">
                ${_conditionType_} a.threshold in
                <foreach collection="conditionParamRef.thresholdList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('thresholdNotList') and conditionParamRef.thresholdNotList.size() > 0">
                ${_conditionType_} a.threshold not in
                <foreach collection="conditionParamRef.thresholdNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('thresholdStart') and conditionParamRef.thresholdStart != null">
                ${_conditionType_} a.threshold <![CDATA[ >= ]]> #{${_conditionParam_}.thresholdStart}
            </if>
            <if test="conditionParamRef.containsKey('thresholdEnd') and conditionParamRef.thresholdEnd != null">
                ${_conditionType_} a.threshold <![CDATA[ <= ]]> #{${_conditionParam_}.thresholdEnd}
            </if>


            <if test="conditionParamRef.containsKey('createTime')">
                <if test="conditionParamRef.createTime != null ">
                    ${_conditionType_} a.createTime = #{${_conditionParam_}.createTime}
                </if>
                <if test="conditionParamRef.createTime == null">
                    ${_conditionType_} a.createTime is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('createTimeStart') and conditionParamRef.createTimeStart != null and conditionParamRef.createTimeStart!=''">
                ${_conditionType_} a.createTime <![CDATA[ >= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.createTimeStart},' 00:00:00'),19),'%Y-%m-%d %k:%i:%s')
            </if>
            <if test="conditionParamRef.containsKey('createTimeEnd') and conditionParamRef.createTimeEnd != null and conditionParamRef.createTimeEnd!=''">
                ${_conditionType_} a.createTime <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.createTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s')
            </if>
            <if test="conditionParamRef.containsKey('createUserId')">
                <if test="conditionParamRef.createUserId != null ">
                    ${_conditionType_} a.createUserId = #{${_conditionParam_}.createUserId}
                </if>
                <if test="conditionParamRef.createUserId == null">
                    ${_conditionType_} a.createUserId is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('createUserIdList') and conditionParamRef.createUserIdList.size() > 0">
                ${_conditionType_} a.createUserId in
                <foreach collection="conditionParamRef.createUserIdList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('createUserIdNotList') and conditionParamRef.createUserIdNotList.size() > 0">
                ${_conditionType_} a.createUserId not in
                <foreach collection="conditionParamRef.createUserIdNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('createUserIdStart') and conditionParamRef.createUserIdStart != null">
                ${_conditionType_} a.createUserId <![CDATA[ >= ]]> #{${_conditionParam_}.createUserIdStart}
            </if>
            <if test="conditionParamRef.containsKey('createUserIdEnd') and conditionParamRef.createUserIdEnd != null">
                ${_conditionType_} a.createUserId <![CDATA[ <= ]]> #{${_conditionParam_}.createUserIdEnd}
            </if>


            <if test="conditionParamRef.containsKey('updateTime')">
                <if test="conditionParamRef.updateTime != null ">
                    ${_conditionType_} a.updateTime = #{${_conditionParam_}.updateTime}
                </if>
                <if test="conditionParamRef.updateTime == null">
                    ${_conditionType_} a.updateTime is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('updateTimeStart') and conditionParamRef.updateTimeStart != null and conditionParamRef.updateTimeStart!=''">
                ${_conditionType_} a.updateTime <![CDATA[ >= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.updateTimeStart},' 00:00:00'),19),'%Y-%m-%d %k:%i:%s')
            </if>
            <if test="conditionParamRef.containsKey('updateTimeEnd') and conditionParamRef.updateTimeEnd != null and conditionParamRef.updateTimeEnd!=''">
                ${_conditionType_} a.updateTime <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.updateTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s')
            </if>
            <if test="conditionParamRef.containsKey('updateUserId')">
                <if test="conditionParamRef.updateUserId != null ">
                    ${_conditionType_} a.updateUserId = #{${_conditionParam_}.updateUserId}
                </if>
                <if test="conditionParamRef.updateUserId == null">
                    ${_conditionType_} a.updateUserId is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdList') and conditionParamRef.updateUserIdList.size() > 0">
                ${_conditionType_} a.updateUserId in
                <foreach collection="conditionParamRef.updateUserIdList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdNotList') and conditionParamRef.updateUserIdNotList.size() > 0">
                ${_conditionType_} a.updateUserId not in
                <foreach collection="conditionParamRef.updateUserIdNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdStart') and conditionParamRef.updateUserIdStart != null">
                ${_conditionType_} a.updateUserId <![CDATA[ >= ]]> #{${_conditionParam_}.updateUserIdStart}
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdEnd') and conditionParamRef.updateUserIdEnd != null">
                ${_conditionType_} a.updateUserId <![CDATA[ <= ]]> #{${_conditionParam_}.updateUserIdEnd}
            </if>

    </sql>
    <sql id="_orderCols_">
        <if test="orderColList != null and !orderColList.isEmpty()">
            order by
            <trim suffixOverrides=","  suffix="">
                <foreach collection="orderColList" open="" close="" index="index" item="item" separator=",">
                     ${item.colName} ${item.sortKind}
                </foreach>
            </trim>
        </if>
        <if test="(orderColList == null or orderColList.isEmpty()) and orderCol != null and !orderCol.isEmpty()">
            order by
            <trim suffixOverrides=","  suffix="">
                    <if test="orderCol.containsKey('id')">
                        a.id
                        <if test='orderCol.id != null and "DESC".equalsIgnoreCase(orderCol.id)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('indexCode')">
                        a.indexCode
                        <if test='orderCol.indexCode != null and "DESC".equalsIgnoreCase(orderCol.indexCode)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('name')">
                        a.name
                        <if test='orderCol.name != null and "DESC".equalsIgnoreCase(orderCol.name)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('faceGroupIndexCodes')">
                        a.faceGroupIndexCodes
                        <if test='orderCol.faceGroupIndexCodes != null and "DESC".equalsIgnoreCase(orderCol.faceGroupIndexCodes)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('cameraIndexCodes')">
                        a.cameraIndexCodes
                        <if test='orderCol.cameraIndexCodes != null and "DESC".equalsIgnoreCase(orderCol.cameraIndexCodes)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('recognitionResourceIndexCodes')">
                        a.recognitionResourceIndexCodes
                        <if test='orderCol.recognitionResourceIndexCodes != null and "DESC".equalsIgnoreCase(orderCol.recognitionResourceIndexCodes)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('recognitionResourceType')">
                        a.recognitionResourceType
                        <if test='orderCol.recognitionResourceType != null and "DESC".equalsIgnoreCase(orderCol.recognitionResourceType)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('recognitionPlanType')">
                        a.recognitionPlanType
                        <if test='orderCol.recognitionPlanType != null and "DESC".equalsIgnoreCase(orderCol.recognitionPlanType)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('status')">
                        a.status
                        <if test='orderCol.status != null and "DESC".equalsIgnoreCase(orderCol.status)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('available')">
                        a.available
                        <if test='orderCol.available != null and "DESC".equalsIgnoreCase(orderCol.available)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('description')">
                        a.description
                        <if test='orderCol.description != null and "DESC".equalsIgnoreCase(orderCol.description)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('startTime')">
                        a.startTime
                        <if test='orderCol.startTime != null and "DESC".equalsIgnoreCase(orderCol.startTime)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('usingTime')">
                        a.usingTime
                        <if test='orderCol.usingTime != null and "DESC".equalsIgnoreCase(orderCol.usingTime)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('threshold')">
                        a.threshold
                        <if test='orderCol.threshold != null and "DESC".equalsIgnoreCase(orderCol.threshold)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('createTime')">
                        a.createTime
                        <if test='orderCol.createTime != null and "DESC".equalsIgnoreCase(orderCol.createTime)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('createUserId')">
                        a.createUserId
                        <if test='orderCol.createUserId != null and "DESC".equalsIgnoreCase(orderCol.createUserId)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('updateTime')">
                        a.updateTime
                        <if test='orderCol.updateTime != null and "DESC".equalsIgnoreCase(orderCol.updateTime)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('updateUserId')">
                        a.updateUserId
                        <if test='orderCol.updateUserId != null and "DESC".equalsIgnoreCase(orderCol.updateUserId)'>DESC</if>
                        ,
                    </if>
            </trim>
        </if>
    </sql>
    <sql id="_group_by_">
        <if test="groupList != null and !groupList.isEmpty()">
            GROUP BY
            <trim suffixOverrides=","  suffix="">
                <foreach collection="groupList" open="" close="" index="index" item="item" separator=",">
                    ${item}
                </foreach>
            </trim>
        </if>
    </sql>
</mapper>