<?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.park.dao.ibatis.ParkDaoImpl"> <!-- 字段和属性映射 --> <resultMap type="ParkEntity" id="ParkEntity-Map"> <id property="id" column="id" /> <result property="name" column="name" /> <result property="code" column="code" /> <result property="introduction" column="introduction" /> <result property="phone" column="phone" /> <result property="address" column="address" /> <result property="icon" column="icon" /> <result property="createUserId" column="create_user_id" /> <result property="createTime" column="create_time" /> <result property="updateTime" column="update_time" /> </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('name') or colPickMode == 1 and data.containsKey('name')))"> a.name, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('code') or colPickMode == 1 and data.containsKey('code')))"> a.code, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('introduction') or colPickMode == 1 and data.containsKey('introduction')))"> a.introduction, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('phone') or colPickMode == 1 and data.containsKey('phone')))"> a.phone, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('address') or colPickMode == 1 and data.containsKey('address')))"> a.address, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('icon') or colPickMode == 1 and data.containsKey('icon')))"> a.icon, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createUserId') or colPickMode == 1 and data.containsKey('createUserId')))"> a.create_user_id, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createTime') or colPickMode == 1 and data.containsKey('createTime')))"> a.create_time, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('updateTime') or colPickMode == 1 and data.containsKey('updateTime')))"> a.update_time, </if> </trim> </sql> <!-- 新增 区分主键自增加还是业务插入 --> <insert id="insert" parameterType="ParkEntity" useGeneratedKeys="true" keyProperty="id"> insert into mortals_agent_park (name,code,introduction,phone,address,icon,create_user_id,create_time,update_time) VALUES (#{name},#{code},#{introduction},#{phone},#{address},#{icon},#{createUserId},#{createTime},#{updateTime}) </insert> <!-- 批量新增 --> <insert id="insertBatch" parameterType="paramDto"> insert into mortals_agent_park (name,code,introduction,phone,address,icon,create_user_id,create_time,update_time) VALUES <foreach collection="data.dataList" item="item" index="index" separator="," > (#{item.name},#{item.code},#{item.introduction},#{item.phone},#{item.address},#{item.icon},#{item.createUserId},#{item.createTime},#{item.updateTime}) </foreach> </insert> <!-- 根据ParamDto更新 --> <update id="update" parameterType="paramDto"> update mortals_agent_park as a set <trim suffixOverrides="," suffix=""> <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('code')) or (colPickMode==1 and !data.containsKey('code'))"> a.code=#{data.code}, </if> <if test="(colPickMode==0 and data.containsKey('introduction')) or (colPickMode==1 and !data.containsKey('introduction'))"> a.introduction=#{data.introduction}, </if> <if test="(colPickMode==0 and data.containsKey('phone')) or (colPickMode==1 and !data.containsKey('phone'))"> a.phone=#{data.phone}, </if> <if test="(colPickMode==0 and data.containsKey('address')) or (colPickMode==1 and !data.containsKey('address'))"> a.address=#{data.address}, </if> <if test="(colPickMode==0 and data.containsKey('icon')) or (colPickMode==1 and !data.containsKey('icon'))"> a.icon=#{data.icon}, </if> <if test="(colPickMode==0 and data.containsKey('createUserId')) or (colPickMode==1 and !data.containsKey('createUserId'))"> a.create_user_id=#{data.createUserId}, </if> <if test="(colPickMode==0 and data.containsKey('createUserIdIncrement')) or (colPickMode==1 and !data.containsKey('createUserIdIncrement'))"> a.create_user_id=ifnull(a.create_user_id,0) + #{data.createUserIdIncrement}, </if> <if test="(colPickMode==0 and data.containsKey('createTime')) or (colPickMode==1 and !data.containsKey('createTime'))"> a.create_time=#{data.createTime}, </if> <if test="(colPickMode==0 and data.containsKey('updateTime')) or (colPickMode==1 and !data.containsKey('updateTime'))"> a.update_time=#{data.updateTime}, </if> </trim> <trim suffixOverrides="where" suffix=""> where <trim prefixOverrides="and" prefix=""> <include refid="_condition_"/> </trim> </trim> </update> <!-- 批量更新 --> <update id="updateBatch" parameterType="paramDto"> update mortals_agent_park as a <trim prefix="set" suffixOverrides=","> <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="code=(case" suffix="ELSE code end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('code')) or (colPickMode==1 and !item.containsKey('code'))"> when a.id=#{item.id} then #{item.code} </if> </foreach> </trim> <trim prefix="introduction=(case" suffix="ELSE introduction end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('introduction')) or (colPickMode==1 and !item.containsKey('introduction'))"> when a.id=#{item.id} then #{item.introduction} </if> </foreach> </trim> <trim prefix="phone=(case" suffix="ELSE phone end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('phone')) or (colPickMode==1 and !item.containsKey('phone'))"> when a.id=#{item.id} then #{item.phone} </if> </foreach> </trim> <trim prefix="address=(case" suffix="ELSE address end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('address')) or (colPickMode==1 and !item.containsKey('address'))"> when a.id=#{item.id} then #{item.address} </if> </foreach> </trim> <trim prefix="icon=(case" suffix="ELSE icon end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('icon')) or (colPickMode==1 and !item.containsKey('icon'))"> when a.id=#{item.id} then #{item.icon} </if> </foreach> </trim> <trim prefix="create_user_id=(case" suffix="ELSE create_user_id 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.create_user_id,0) + #{item.createUserIdIncrement} </when> </choose> </foreach> </trim> <trim prefix="create_time=(case" suffix="ELSE create_time 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="update_time=(case" suffix="ELSE update_time 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> where id in <foreach collection="data.dataList" item="item" index="index" open="(" separator="," close=")"> #{item.id} </foreach> </update> <!-- 根据主健查询 --> <select id="getByKey" parameterType="paramDto" resultMap="ParkEntity-Map"> select <include refid="_columns"/> from mortals_agent_park as a where a.id=#{condition.id} </select> <!-- 根据主健删除 --> <delete id="deleteByKey" parameterType="paramDto"> delete from mortals_agent_park where id=#{condition.id} </delete> <!-- 根据主健删除一批,针对单一主健有效 --> <delete id="deleteByKeys"> delete from mortals_agent_park where id in <foreach collection="array" item="item" index="index" open="(" separator="," close=")"> #{item} </foreach> </delete> <!-- 根据主健列表删除一批,针对单一主健有效 --> <delete id="deleteByKeyList"> delete from mortals_agent_park where id in <foreach collection="list" item="item" index="index" open="(" separator="," close=")"> #{item} </foreach> </delete> <!-- 根据对象列表删除一批,针对单一主健有效 --> <delete id="deleteByEntityList"> delete from mortals_agent_park 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_agent_park as a <trim suffixOverrides="where" suffix=""> where <trim prefixOverrides="and" prefix=""> <include refid="_condition_"/> </trim> </trim> </delete> <!-- 获取列表 --> <select id="getList" parameterType="paramDto" resultMap="ParkEntity-Map"> select <include refid="_columns"/> from mortals_agent_park 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_agent_park 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="permissionSql != null and permissionSql != ''"> ${permissionSql} </if> <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('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('code')"> <if test="conditionParamRef.code != null and conditionParamRef.code != ''"> ${_conditionType_} a.code like #{${_conditionParam_}.code} </if> <if test="conditionParamRef.code == null"> ${_conditionType_} a.code is null </if> </if> <if test="conditionParamRef.containsKey('codeList') and conditionParamRef.codeList.size() > 0"> ${_conditionType_} a.code in <foreach collection="conditionParamRef.codeList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('codeNotList') and conditionParamRef.codeNotList.size() > 0"> ${_conditionType_} a.code not in <foreach collection="conditionParamRef.codeNotList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('introduction')"> <if test="conditionParamRef.introduction != null and conditionParamRef.introduction != ''"> ${_conditionType_} a.introduction like #{${_conditionParam_}.introduction} </if> <if test="conditionParamRef.introduction == null"> ${_conditionType_} a.introduction is null </if> </if> <if test="conditionParamRef.containsKey('introductionList') and conditionParamRef.introductionList.size() > 0"> ${_conditionType_} a.introduction in <foreach collection="conditionParamRef.introductionList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('introductionNotList') and conditionParamRef.introductionNotList.size() > 0"> ${_conditionType_} a.introduction not in <foreach collection="conditionParamRef.introductionNotList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('phone')"> <if test="conditionParamRef.phone != null and conditionParamRef.phone != ''"> ${_conditionType_} a.phone like #{${_conditionParam_}.phone} </if> <if test="conditionParamRef.phone == null"> ${_conditionType_} a.phone is null </if> </if> <if test="conditionParamRef.containsKey('phoneList') and conditionParamRef.phoneList.size() > 0"> ${_conditionType_} a.phone in <foreach collection="conditionParamRef.phoneList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('phoneNotList') and conditionParamRef.phoneNotList.size() > 0"> ${_conditionType_} a.phone not in <foreach collection="conditionParamRef.phoneNotList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('address')"> <if test="conditionParamRef.address != null and conditionParamRef.address != ''"> ${_conditionType_} a.address like #{${_conditionParam_}.address} </if> <if test="conditionParamRef.address == null"> ${_conditionType_} a.address is null </if> </if> <if test="conditionParamRef.containsKey('addressList') and conditionParamRef.addressList.size() > 0"> ${_conditionType_} a.address in <foreach collection="conditionParamRef.addressList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('addressNotList') and conditionParamRef.addressNotList.size() > 0"> ${_conditionType_} a.address not in <foreach collection="conditionParamRef.addressNotList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('icon')"> <if test="conditionParamRef.icon != null and conditionParamRef.icon != ''"> ${_conditionType_} a.icon like #{${_conditionParam_}.icon} </if> <if test="conditionParamRef.icon == null"> ${_conditionType_} a.icon is null </if> </if> <if test="conditionParamRef.containsKey('iconList') and conditionParamRef.iconList.size() > 0"> ${_conditionType_} a.icon in <foreach collection="conditionParamRef.iconList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('iconNotList') and conditionParamRef.iconNotList.size() > 0"> ${_conditionType_} a.icon not in <foreach collection="conditionParamRef.iconNotList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('createUserId')"> <if test="conditionParamRef.createUserId != null "> ${_conditionType_} a.create_user_id = #{${_conditionParam_}.createUserId} </if> <if test="conditionParamRef.createUserId == null"> ${_conditionType_} a.create_user_id is null </if> </if> <if test="conditionParamRef.containsKey('createUserIdList') and conditionParamRef.createUserIdList.size() > 0"> ${_conditionType_} a.create_user_id 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.create_user_id 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.create_user_id <![CDATA[ >= ]]> #{${_conditionParam_}.createUserIdStart} </if> <if test="conditionParamRef.containsKey('createUserIdEnd') and conditionParamRef.createUserIdEnd != null"> ${_conditionType_} a.create_user_id <![CDATA[ <= ]]> #{${_conditionParam_}.createUserIdEnd} </if> <if test="conditionParamRef.containsKey('createTime')"> <if test="conditionParamRef.createTime != null "> ${_conditionType_} a.create_time = #{${_conditionParam_}.createTime} </if> <if test="conditionParamRef.createTime == null"> ${_conditionType_} a.create_time is null </if> </if> <if test="conditionParamRef.containsKey('createTimeStart') and conditionParamRef.createTimeStart != null and conditionParamRef.createTimeStart!=''"> ${_conditionType_} a.create_time <![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.create_time <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.createTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s') </if> <if test="conditionParamRef.containsKey('updateTime')"> <if test="conditionParamRef.updateTime != null "> ${_conditionType_} a.update_time = #{${_conditionParam_}.updateTime} </if> <if test="conditionParamRef.updateTime == null"> ${_conditionType_} a.update_time is null </if> </if> <if test="conditionParamRef.containsKey('updateTimeStart') and conditionParamRef.updateTimeStart != null and conditionParamRef.updateTimeStart!=''"> ${_conditionType_} a.update_time <![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.update_time <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.updateTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s') </if> </sql> <sql id="_orderCols_"> <if test="orderColList != null and !orderColList.isEmpty()"> order by <if test="conditionParamRef.containsKey('idList') and conditionParamRef.idList.size() > 0"> field(a.id, <foreach collection="conditionParamRef.idList" open="" close=")" index="index" item="item" separator=","> #{item} </foreach> , </if> <if test="conditionParamRef.containsKey('createUserIdList') and conditionParamRef.createUserIdList.size() > 0"> field(a.create_user_id, <foreach collection="conditionParamRef.createUserIdList" open="" close=")" index="index" item="item" separator=","> #{item} </foreach> , </if> <trim suffixOverrides="," suffix=""> <foreach collection="orderColList" open="" close="" index="index" item="item" separator=","> a.${item.colName} ${item.sortKind} </foreach> </trim> </if> <if test="(orderColList == null or orderColList.isEmpty()) and orderCol != null and !orderCol.isEmpty()"> order by <if test="conditionParamRef.containsKey('idList') and conditionParamRef.idList.size() > 0"> field(a.id, <foreach collection="conditionParamRef.idList" open="" close=")" index="index" item="item" separator=","> #{item} </foreach> , </if> <if test="conditionParamRef.containsKey('createUserIdList') and conditionParamRef.createUserIdList.size() > 0"> field(a.create_user_id, <foreach collection="conditionParamRef.createUserIdList" open="" close=")" index="index" item="item" separator=","> #{item} </foreach> , </if> <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('name')"> a.name <if test='orderCol.name != null and "DESC".equalsIgnoreCase(orderCol.name)'>DESC</if> , </if> <if test="orderCol.containsKey('code')"> a.code <if test='orderCol.code != null and "DESC".equalsIgnoreCase(orderCol.code)'>DESC</if> , </if> <if test="orderCol.containsKey('introduction')"> a.introduction <if test='orderCol.introduction != null and "DESC".equalsIgnoreCase(orderCol.introduction)'>DESC</if> , </if> <if test="orderCol.containsKey('phone')"> a.phone <if test='orderCol.phone != null and "DESC".equalsIgnoreCase(orderCol.phone)'>DESC</if> , </if> <if test="orderCol.containsKey('address')"> a.address <if test='orderCol.address != null and "DESC".equalsIgnoreCase(orderCol.address)'>DESC</if> , </if> <if test="orderCol.containsKey('icon')"> a.icon <if test='orderCol.icon != null and "DESC".equalsIgnoreCase(orderCol.icon)'>DESC</if> , </if> <if test="orderCol.containsKey('createUserId')"> a.create_user_id <if test='orderCol.createUserId != null and "DESC".equalsIgnoreCase(orderCol.createUserId)'>DESC</if> , </if> <if test="orderCol.containsKey('createTime')"> a.create_time <if test='orderCol.createTime != null and "DESC".equalsIgnoreCase(orderCol.createTime)'>DESC</if> , </if> <if test="orderCol.containsKey('updateTime')"> a.update_time <if test='orderCol.updateTime != null and "DESC".equalsIgnoreCase(orderCol.updateTime)'>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>