<?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.yth.dao.ibatis.YthWarrntsetDaoImpl">

    <!-- 字段和属性映射 -->
    <resultMap type="YthWarrntsetEntity" id="YthWarrntsetEntity-Map">
        <result property="id" column="id" />
        <result property="matterid" column="matterid" />
        <result property="lawName" column="lawName" />
        <result property="lawType" column="lawType" />
        <result property="referenceNum" column="referenceNum" />
        <result property="clause" column="clause" />
        <result property="clauseContent" column="clauseContent" />
        <result property="sort" column="sort" />
        <result property="createTime" column="createTime" />
        <result property="createUser" column="createUser" />
    </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 as id,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('matterid') or colPickMode == 1 and data.containsKey('matterid')))">
                    a.matterid as matterid,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('lawName') or colPickMode == 1 and data.containsKey('lawName')))">
                    a.lawName as lawName,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('lawType') or colPickMode == 1 and data.containsKey('lawType')))">
                    a.lawType as lawType,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('referenceNum') or colPickMode == 1 and data.containsKey('referenceNum')))">
                    a.referenceNum as referenceNum,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('clause') or colPickMode == 1 and data.containsKey('clause')))">
                    a.clause as clause,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('clauseContent') or colPickMode == 1 and data.containsKey('clauseContent')))">
                    a.clauseContent as clauseContent,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('sort') or colPickMode == 1 and data.containsKey('sort')))">
                    a.sort as sort,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createTime') or colPickMode == 1 and data.containsKey('createTime')))">
                    a.createTime as createTime,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createUser') or colPickMode == 1 and data.containsKey('createUser')))">
                    a.createUser as createUser,
                </if>
        </trim>
    </sql>
    <!-- 新增 -->
        <insert id="insert" parameterType="YthWarrntsetEntity" useGeneratedKeys="true" keyProperty="id">
            insert into mortals_xhx_yth_warrntset
            (matterid,lawName,lawType,referenceNum,clause,clauseContent,sort,createTime,createUser)
            VALUES
            (#{matterid},#{lawName},#{lawType},#{referenceNum},#{clause},#{clauseContent},#{sort},#{createTime},#{createUser})
        </insert>

        <!-- 批量新增 -->
        <insert id="insertBatch" parameterType="paramDto">
            insert into mortals_xhx_yth_warrntset
            (matterid,lawName,lawType,referenceNum,clause,clauseContent,sort,createTime,createUser)
            VALUES
            <foreach collection="data.dataList" item="item" index="index" separator="," >
                (#{item.matterid},#{item.lawName},#{item.lawType},#{item.referenceNum},#{item.clause},#{item.clauseContent},#{item.sort},#{item.createTime},#{item.createUser})
            </foreach>
        </insert>
    <!-- 根据ParamDto更新 -->
    <update id="update" parameterType="paramDto">
        update mortals_xhx_yth_warrntset as a
        set
        <trim suffixOverrides="," suffix="">
            <if test="(colPickMode==0 and data.containsKey('matterid')) or (colPickMode==1 and !data.containsKey('matterid'))">
                a.matterid=#{data.matterid},
            </if>
            <if test="(colPickMode==0 and data.containsKey('matteridIncrement')) or (colPickMode==1 and !data.containsKey('matteridIncrement'))">
                a.matterid=ifnull(a.matterid,0) + #{data.matteridIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('lawName')) or (colPickMode==1 and !data.containsKey('lawName'))">
                a.lawName=#{data.lawName},
            </if>
            <if test="(colPickMode==0 and data.containsKey('lawType')) or (colPickMode==1 and !data.containsKey('lawType'))">
                a.lawType=#{data.lawType},
            </if>
            <if test="(colPickMode==0 and data.containsKey('lawTypeIncrement')) or (colPickMode==1 and !data.containsKey('lawTypeIncrement'))">
                a.lawType=ifnull(a.lawType,0) + #{data.lawTypeIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('referenceNum')) or (colPickMode==1 and !data.containsKey('referenceNum'))">
                a.referenceNum=#{data.referenceNum},
            </if>
            <if test="(colPickMode==0 and data.containsKey('clause')) or (colPickMode==1 and !data.containsKey('clause'))">
                a.clause=#{data.clause},
            </if>
            <if test="(colPickMode==0 and data.containsKey('clauseContent')) or (colPickMode==1 and !data.containsKey('clauseContent'))">
                a.clauseContent=#{data.clauseContent},
            </if>
            <if test="(colPickMode==0 and data.containsKey('sort')) or (colPickMode==1 and !data.containsKey('sort'))">
                a.sort=#{data.sort},
            </if>
            <if test="(colPickMode==0 and data.containsKey('sortIncrement')) or (colPickMode==1 and !data.containsKey('sortIncrement'))">
                a.sort=ifnull(a.sort,0) + #{data.sortIncrement},
            </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('createUser')) or (colPickMode==1 and !data.containsKey('createUser'))">
                a.createUser=#{data.createUser},
            </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_yth_warrntset as a
        <trim prefix="set" suffixOverrides=",">


                        <trim prefix="matterid=(case" suffix="ELSE matterid end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('matterid')) or (colPickMode==1 and !item.containsKey('matterid'))">
                                        when a.id=#{item.id} then #{item.matterid}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('matteridIncrement')) or (colPickMode==1 and !item.containsKey('matteridIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.matterid,0) + #{item.matteridIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>

                <trim prefix="lawName=(case" suffix="ELSE lawName end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('lawName')) or (colPickMode==1 and !item.containsKey('lawName'))">
                            when a.id=#{item.id} then #{item.lawName}
                        </if>
                    </foreach>
                </trim>

                        <trim prefix="lawType=(case" suffix="ELSE lawType end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('lawType')) or (colPickMode==1 and !item.containsKey('lawType'))">
                                        when a.id=#{item.id} then #{item.lawType}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('lawTypeIncrement')) or (colPickMode==1 and !item.containsKey('lawTypeIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.lawType,0) + #{item.lawTypeIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>

                <trim prefix="referenceNum=(case" suffix="ELSE referenceNum end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('referenceNum')) or (colPickMode==1 and !item.containsKey('referenceNum'))">
                            when a.id=#{item.id} then #{item.referenceNum}
                        </if>
                    </foreach>
                </trim>

                <trim prefix="clause=(case" suffix="ELSE clause end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('clause')) or (colPickMode==1 and !item.containsKey('clause'))">
                            when a.id=#{item.id} then #{item.clause}
                        </if>
                    </foreach>
                </trim>

                <trim prefix="clauseContent=(case" suffix="ELSE clauseContent end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('clauseContent')) or (colPickMode==1 and !item.containsKey('clauseContent'))">
                            when a.id=#{item.id} then #{item.clauseContent}
                        </if>
                    </foreach>
                </trim>

                        <trim prefix="sort=(case" suffix="ELSE sort end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('sort')) or (colPickMode==1 and !item.containsKey('sort'))">
                                        when a.id=#{item.id} then #{item.sort}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('sortIncrement')) or (colPickMode==1 and !item.containsKey('sortIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.sort,0) + #{item.sortIncrement}
                                    </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="createUser=(case" suffix="ELSE createUser end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('createUser')) or (colPickMode==1 and !item.containsKey('createUser'))">
                            when a.id=#{item.id} then #{item.createUser}
                        </if>
                    </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="YthWarrntsetEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_yth_warrntset as a
        where a.id=#{condition.id}
    </select>
    <!-- 根据主健删除 -->
    <delete id="deleteByKey" parameterType="paramDto">
        delete a.* from mortals_xhx_yth_warrntset as a where a.id=#{condition.id}
    </delete>
    <!-- 根据主健删除一批,针对单一主健有效 -->
    <delete id="deleteByKeys">
        delete from mortals_xhx_yth_warrntset where id in
        <foreach collection="array" item="item" index="index" open="(" separator="," close=")">
            #{item}
        </foreach>
    </delete>
    <!-- 根据paramDto删除一批 -->
    <delete id="deleteByMap" parameterType="paramDto">
        delete a.* from mortals_xhx_yth_warrntset as a
        <trim suffixOverrides="where" suffix="">
            where
            <trim prefixOverrides="and" prefix="">
                <include refid="_condition_"/>
            </trim>
        </trim>
    </delete>
    <!-- 获取列表 -->
    <select id="getList" parameterType="paramDto" resultMap="YthWarrntsetEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_yth_warrntset 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_yth_warrntset 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')">
                ${_conditionType_} a.id in
                <foreach collection="conditionParamRef.idList" 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('matterid')">
                <if test="conditionParamRef.matterid != null ">
                    ${_conditionType_} a.matterid = #{${_conditionParam_}.matterid}
                </if>
                <if test="conditionParamRef.matterid == null">
                    ${_conditionType_} a.matterid is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('matteridList')">
                ${_conditionType_} a.matterid in
                <foreach collection="conditionParamRef.matteridList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('matteridStart') and conditionParamRef.matteridStart != null">
                ${_conditionType_} a.matterid <![CDATA[ >= ]]> #{${_conditionParam_}.matteridStart}
            </if>
            <if test="conditionParamRef.containsKey('matteridEnd') and conditionParamRef.matteridEnd != null">
                ${_conditionType_} a.matterid <![CDATA[ <= ]]> #{${_conditionParam_}.matteridEnd}
            </if>


            <if test="conditionParamRef.containsKey('lawName')">
                <if test="conditionParamRef.lawName != null and conditionParamRef.lawName != ''">
                    ${_conditionType_} a.lawName like #{${_conditionParam_}.lawName}
                </if>
                <if test="conditionParamRef.lawName == null">
                    ${_conditionType_} a.lawName is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('lawNameList')">
                ${_conditionType_} a.lawName in
                <foreach collection="conditionParamRef.lawNameList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('lawType')">
                <if test="conditionParamRef.lawType != null ">
                    ${_conditionType_} a.lawType = #{${_conditionParam_}.lawType}
                </if>
                <if test="conditionParamRef.lawType == null">
                    ${_conditionType_} a.lawType is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('lawTypeList')">
                ${_conditionType_} a.lawType in
                <foreach collection="conditionParamRef.lawTypeList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('lawTypeStart') and conditionParamRef.lawTypeStart != null">
                ${_conditionType_} a.lawType <![CDATA[ >= ]]> #{${_conditionParam_}.lawTypeStart}
            </if>
            <if test="conditionParamRef.containsKey('lawTypeEnd') and conditionParamRef.lawTypeEnd != null">
                ${_conditionType_} a.lawType <![CDATA[ <= ]]> #{${_conditionParam_}.lawTypeEnd}
            </if>


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

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

            <if test="conditionParamRef.containsKey('clauseContent')">
                <if test="conditionParamRef.clauseContent != null and conditionParamRef.clauseContent != ''">
                    ${_conditionType_} a.clauseContent like #{${_conditionParam_}.clauseContent}
                </if>
                <if test="conditionParamRef.clauseContent == null">
                    ${_conditionType_} a.clauseContent is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('clauseContentList')">
                ${_conditionType_} a.clauseContent in
                <foreach collection="conditionParamRef.clauseContentList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('sort')">
                <if test="conditionParamRef.sort != null ">
                    ${_conditionType_} a.sort = #{${_conditionParam_}.sort}
                </if>
                <if test="conditionParamRef.sort == null">
                    ${_conditionType_} a.sort is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('sortList')">
                ${_conditionType_} a.sort in
                <foreach collection="conditionParamRef.sortList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('sortStart') and conditionParamRef.sortStart != null">
                ${_conditionType_} a.sort <![CDATA[ >= ]]> #{${_conditionParam_}.sortStart}
            </if>
            <if test="conditionParamRef.containsKey('sortEnd') and conditionParamRef.sortEnd != null">
                ${_conditionType_} a.sort <![CDATA[ <= ]]> #{${_conditionParam_}.sortEnd}
            </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('createUser')">
                <if test="conditionParamRef.createUser != null and conditionParamRef.createUser != ''">
                    ${_conditionType_} a.createUser like #{${_conditionParam_}.createUser}
                </if>
                <if test="conditionParamRef.createUser == null">
                    ${_conditionType_} a.createUser is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('createUserList')">
                ${_conditionType_} a.createUser in
                <foreach collection="conditionParamRef.createUserList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </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('matterid')">
                        a.matterid
                        <if test='orderCol.matterid != null and "DESC".equalsIgnoreCase(orderCol.matterid)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('lawName')">
                        a.lawName
                        <if test='orderCol.lawName != null and "DESC".equalsIgnoreCase(orderCol.lawName)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('lawType')">
                        a.lawType
                        <if test='orderCol.lawType != null and "DESC".equalsIgnoreCase(orderCol.lawType)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('referenceNum')">
                        a.referenceNum
                        <if test='orderCol.referenceNum != null and "DESC".equalsIgnoreCase(orderCol.referenceNum)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('clause')">
                        a.clause
                        <if test='orderCol.clause != null and "DESC".equalsIgnoreCase(orderCol.clause)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('clauseContent')">
                        a.clauseContent
                        <if test='orderCol.clauseContent != null and "DESC".equalsIgnoreCase(orderCol.clauseContent)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('sort')">
                        a.sort
                        <if test='orderCol.sort != null and "DESC".equalsIgnoreCase(orderCol.sort)'>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('createUser')">
                        a.createUser
                        <if test='orderCol.createUser != null and "DESC".equalsIgnoreCase(orderCol.createUser)'>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>