<?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.base.system.user.dao.ibatis.UserDaoImpl">

    <!-- 字段和属性映射 -->
    <resultMap type="UserEntity" id="UserEntity-Map">
        <id  property="id" column="id" />
        <result property="loginName" column="loginName" />
        <result property="loginPwd" column="loginPwd" />
        <result property="loginLimitAddress" column="loginLimitAddress" />
        <result property="realName" column="realName" />
        <result property="mobile" column="mobile" />
        <result property="phone" column="phone" />
        <result property="email" column="email" />
        <result property="qq" column="qq" />
        <result property="userType" column="userType" />
        <result property="siteIds" column="siteIds" />
        <result property="areaCodes" column="areaCodes" />
        <result property="status" column="status" />
        <result property="createTime" column="createTime" />
        <result property="createUserId" column="createUserId" />
        <result property="createUserName" column="createUserName" />
        <result property="lastLoginTime" column="lastLoginTime" />
        <result property="lastLoginAddress" column="lastLoginAddress" />

    </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('loginName') or colPickMode == 1 and data.containsKey('loginName')))">
                a.loginName,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('loginPwd') or colPickMode == 1 and data.containsKey('loginPwd')))">
                a.loginPwd,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('loginLimitAddress') or colPickMode == 1 and data.containsKey('loginLimitAddress')))">
                a.loginLimitAddress,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('realName') or colPickMode == 1 and data.containsKey('realName')))">
                a.realName,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('mobile') or colPickMode == 1 and data.containsKey('mobile')))">
                a.mobile,
            </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('email') or colPickMode == 1 and data.containsKey('email')))">
                a.email,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('qq') or colPickMode == 1 and data.containsKey('qq')))">
                a.qq,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('userType') or colPickMode == 1 and data.containsKey('userType')))">
                a.userType,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('siteIds') or colPickMode == 1 and data.containsKey('siteIds')))">
                a.siteIds,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('areaCodes') or colPickMode == 1 and data.containsKey('areaCodes')))">
                a.areaCodes,
            </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('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('createUserName') or colPickMode == 1 and data.containsKey('createUserName')))">
                a.createUserName,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('lastLoginTime') or colPickMode == 1 and data.containsKey('lastLoginTime')))">
                a.lastLoginTime,
            </if>
            <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('lastLoginAddress') or colPickMode == 1 and data.containsKey('lastLoginAddress')))">
                a.lastLoginAddress,
            </if>
        </trim>
    </sql>
    <!-- 新增 区分主键自增加还是业务插入 -->
    <insert id="insert" parameterType="UserEntity"  useGeneratedKeys="true" keyProperty="id">
        insert into mortals_xhx_user
        (loginName,loginPwd,loginLimitAddress,realName,mobile,phone,email,qq,userType,siteIds,areaCodes,status,createTime,createUserId,createUserName,lastLoginTime,lastLoginAddress)
        VALUES
        (#{loginName},#{loginPwd},#{loginLimitAddress},#{realName},#{mobile},#{phone},#{email},#{qq},#{userType},#{siteIds},#{areaCodes},#{status},#{createTime},#{createUserId},#{createUserName},#{lastLoginTime},#{lastLoginAddress})
    </insert>

    <!-- 批量新增 -->
    <insert id="insertBatch" parameterType="paramDto">
        insert into mortals_xhx_user
        (loginName,loginPwd,loginLimitAddress,realName,mobile,phone,email,qq,userType,siteIds,areaCodes,status,createTime,createUserId,createUserName,lastLoginTime,lastLoginAddress)
        VALUES
        <foreach collection="data.dataList" item="item" index="index" separator="," >
            (#{item.loginName},#{item.loginPwd},#{item.loginLimitAddress},#{item.realName},#{item.mobile},#{item.phone},#{item.email},#{item.qq},#{item.userType},#{item.siteIds},#{item.areaCodes},#{item.status},#{item.createTime},#{item.createUserId},#{item.createUserName},#{item.lastLoginTime},#{item.lastLoginAddress})
        </foreach>
    </insert>


    <!-- 根据ParamDto更新 -->
    <update id="update" parameterType="paramDto">
        update mortals_xhx_user as a
        set
        <trim suffixOverrides="," suffix="">
            <if test="(colPickMode==0 and data.containsKey('loginName')) or (colPickMode==1 and !data.containsKey('loginName'))">
                a.loginName=#{data.loginName},
            </if>
            <if test="(colPickMode==0 and data.containsKey('loginPwd')) or (colPickMode==1 and !data.containsKey('loginPwd'))">
                a.loginPwd=#{data.loginPwd},
            </if>
            <if test="(colPickMode==0 and data.containsKey('loginLimitAddress')) or (colPickMode==1 and !data.containsKey('loginLimitAddress'))">
                a.loginLimitAddress=#{data.loginLimitAddress},
            </if>
            <if test="(colPickMode==0 and data.containsKey('realName')) or (colPickMode==1 and !data.containsKey('realName'))">
                a.realName=#{data.realName},
            </if>
            <if test="(colPickMode==0 and data.containsKey('mobile')) or (colPickMode==1 and !data.containsKey('mobile'))">
                a.mobile=#{data.mobile},
            </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('email')) or (colPickMode==1 and !data.containsKey('email'))">
                a.email=#{data.email},
            </if>
            <if test="(colPickMode==0 and data.containsKey('qq')) or (colPickMode==1 and !data.containsKey('qq'))">
                a.qq=#{data.qq},
            </if>
            <if test="(colPickMode==0 and data.containsKey('userType')) or (colPickMode==1 and !data.containsKey('userType'))">
                a.userType=#{data.userType},
            </if>
            <if test="(colPickMode==0 and data.containsKey('userTypeIncrement')) or (colPickMode==1 and !data.containsKey('userTypeIncrement'))">
                a.userType=ifnull(a.userType,0) + #{data.userTypeIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('siteIds')) or (colPickMode==1 and !data.containsKey('siteIds'))">
                a.siteIds=#{data.siteIds},
            </if>
            <if test="(colPickMode==0 and data.containsKey('areaCodes')) or (colPickMode==1 and !data.containsKey('areaCodes'))">
                a.areaCodes=#{data.areaCodes},
            </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('statusIncrement')) or (colPickMode==1 and !data.containsKey('statusIncrement'))">
                a.status=ifnull(a.status,0) + #{data.statusIncrement},
            </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('createUserName')) or (colPickMode==1 and !data.containsKey('createUserName'))">
                a.createUserName=#{data.createUserName},
            </if>
            <if test="(colPickMode==0 and data.containsKey('lastLoginTime')) or (colPickMode==1 and !data.containsKey('lastLoginTime'))">
                a.lastLoginTime=#{data.lastLoginTime},
            </if>
            <if test="(colPickMode==0 and data.containsKey('lastLoginAddress')) or (colPickMode==1 and !data.containsKey('lastLoginAddress'))">
                a.lastLoginAddress=#{data.lastLoginAddress},
            </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_user as a
        <trim prefix="set" suffixOverrides=",">
            <trim prefix="loginName=(case" suffix="ELSE loginName end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('loginName')) or (colPickMode==1 and !item.containsKey('loginName'))">
                        when a.id=#{item.id} then #{item.loginName}
                    </if>
                </foreach>
            </trim>
            <trim prefix="loginPwd=(case" suffix="ELSE loginPwd end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('loginPwd')) or (colPickMode==1 and !item.containsKey('loginPwd'))">
                        when a.id=#{item.id} then #{item.loginPwd}
                    </if>
                </foreach>
            </trim>
            <trim prefix="loginLimitAddress=(case" suffix="ELSE loginLimitAddress end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('loginLimitAddress')) or (colPickMode==1 and !item.containsKey('loginLimitAddress'))">
                        when a.id=#{item.id} then #{item.loginLimitAddress}
                    </if>
                </foreach>
            </trim>
            <trim prefix="realName=(case" suffix="ELSE realName end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('realName')) or (colPickMode==1 and !item.containsKey('realName'))">
                        when a.id=#{item.id} then #{item.realName}
                    </if>
                </foreach>
            </trim>
            <trim prefix="mobile=(case" suffix="ELSE mobile end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('mobile')) or (colPickMode==1 and !item.containsKey('mobile'))">
                        when a.id=#{item.id} then #{item.mobile}
                    </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="email=(case" suffix="ELSE email end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('email')) or (colPickMode==1 and !item.containsKey('email'))">
                        when a.id=#{item.id} then #{item.email}
                    </if>
                </foreach>
            </trim>
            <trim prefix="qq=(case" suffix="ELSE qq end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('qq')) or (colPickMode==1 and !item.containsKey('qq'))">
                        when a.id=#{item.id} then #{item.qq}
                    </if>
                </foreach>
            </trim>
            <trim prefix="userType=(case" suffix="ELSE userType end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <choose>
                        <when test="(colPickMode==0 and item.containsKey('userType')) or (colPickMode==1 and !item.containsKey('userType'))">
                            when a.id=#{item.id} then #{item.userType}
                        </when>
                        <when test="(colPickMode==0 and item.containsKey('userTypeIncrement')) or (colPickMode==1 and !item.containsKey('userTypeIncrement'))">
                            when a.id=#{item.id} then ifnull(a.userType,0) + #{item.userTypeIncrement}
                        </when>
                    </choose>
                </foreach>
            </trim>
            <trim prefix="siteIds=(case" suffix="ELSE siteIds end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('siteIds')) or (colPickMode==1 and !item.containsKey('siteIds'))">
                        when a.id=#{item.id} then #{item.siteIds}
                    </if>
                </foreach>
            </trim>
            <trim prefix="areaCodes=(case" suffix="ELSE areaCodes end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('areaCodes')) or (colPickMode==1 and !item.containsKey('areaCodes'))">
                        when a.id=#{item.id} then #{item.areaCodes}
                    </if>
                </foreach>
            </trim>
            <trim prefix="status=(case" suffix="ELSE status end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <choose>
                        <when test="(colPickMode==0 and item.containsKey('status')) or (colPickMode==1 and !item.containsKey('status'))">
                            when a.id=#{item.id} then #{item.status}
                        </when>
                        <when test="(colPickMode==0 and item.containsKey('statusIncrement')) or (colPickMode==1 and !item.containsKey('statusIncrement'))">
                            when a.id=#{item.id} then ifnull(a.status,0) + #{item.statusIncrement}
                        </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="createUserName=(case" suffix="ELSE createUserName end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('createUserName')) or (colPickMode==1 and !item.containsKey('createUserName'))">
                        when a.id=#{item.id} then #{item.createUserName}
                    </if>
                </foreach>
            </trim>
            <trim prefix="lastLoginTime=(case" suffix="ELSE lastLoginTime end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('lastLoginTime')) or (colPickMode==1 and !item.containsKey('lastLoginTime'))">
                        when a.id=#{item.id} then #{item.lastLoginTime}
                    </if>
                </foreach>
            </trim>
            <trim prefix="lastLoginAddress=(case" suffix="ELSE lastLoginAddress end),">
                <foreach collection="data.dataList" item="item" index="index" separator="" >
                    <if test="(colPickMode==0 and item.containsKey('lastLoginAddress')) or (colPickMode==1 and !item.containsKey('lastLoginAddress'))">
                        when a.id=#{item.id} then #{item.lastLoginAddress}
                    </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="UserEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_user as a
        where a.id=#{condition.id}
    </select>
    <!-- 根据主健删除 -->
    <delete id="deleteByKey" parameterType="paramDto">
        delete a.* from mortals_xhx_user as a where a.id=#{condition.id}
    </delete>
    <!-- 根据主健删除一批,针对单一主健有效 -->
    <delete id="deleteByKeys">
        delete from mortals_xhx_user 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_user as a
        <trim suffixOverrides="where" suffix="">
            where
            <trim prefixOverrides="and" prefix="">
                <include refid="_condition_"/>
            </trim>
        </trim>
    </delete>
    <!-- 获取列表 -->
    <select id="getList" parameterType="paramDto" resultMap="UserEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_user 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_user 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('loginName')">
            <if test="conditionParamRef.loginName != null and conditionParamRef.loginName != ''">
                ${_conditionType_} a.loginName like #{${_conditionParam_}.loginName}
            </if>
            <if test="conditionParamRef.loginName == null">
                ${_conditionType_} a.loginName is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('loginNameList')">
            ${_conditionType_} a.loginName in
            <foreach collection="conditionParamRef.loginNameList" open="(" close=")" index="index" item="item" separator=",">
                #{item}
            </foreach>
        </if>

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

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

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

        <if test="conditionParamRef.containsKey('mobile')">
            <if test="conditionParamRef.mobile != null and conditionParamRef.mobile != ''">
                ${_conditionType_} a.mobile like #{${_conditionParam_}.mobile}
            </if>
            <if test="conditionParamRef.mobile == null">
                ${_conditionType_} a.mobile is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('mobileList')">
            ${_conditionType_} a.mobile in
            <foreach collection="conditionParamRef.mobileList" 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')">
            ${_conditionType_} a.phone in
            <foreach collection="conditionParamRef.phoneList" open="(" close=")" index="index" item="item" separator=",">
                #{item}
            </foreach>
        </if>

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

        <if test="conditionParamRef.containsKey('qq')">
            <if test="conditionParamRef.qq != null and conditionParamRef.qq != ''">
                ${_conditionType_} a.qq like #{${_conditionParam_}.qq}
            </if>
            <if test="conditionParamRef.qq == null">
                ${_conditionType_} a.qq is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('qqList')">
            ${_conditionType_} a.qq in
            <foreach collection="conditionParamRef.qqList" open="(" close=")" index="index" item="item" separator=",">
                #{item}
            </foreach>
        </if>
        <if test="conditionParamRef.containsKey('userType')">
            <if test="conditionParamRef.userType != null ">
                ${_conditionType_} a.userType = #{${_conditionParam_}.userType}
            </if>
            <if test="conditionParamRef.userType == null">
                ${_conditionType_} a.userType is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('userTypeList')">
            ${_conditionType_} a.userType in
            <foreach collection="conditionParamRef.userTypeList" open="(" close=")" index="index" item="item" separator=",">
                #{item}
            </foreach>
        </if>
        <if test="conditionParamRef.containsKey('userTypeStart') and conditionParamRef.userTypeStart != null">
            ${_conditionType_} a.userType <![CDATA[ >= ]]> #{${_conditionParam_}.userTypeStart}
        </if>
        <if test="conditionParamRef.containsKey('userTypeEnd') and conditionParamRef.userTypeEnd != null">
            ${_conditionType_} a.userType <![CDATA[ <= ]]> #{${_conditionParam_}.userTypeEnd}
        </if>


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

        <if test="conditionParamRef.containsKey('areaCodes')">
            <if test="conditionParamRef.areaCodes != null and conditionParamRef.areaCodes != ''">
                ${_conditionType_} a.areaCodes like #{${_conditionParam_}.areaCodes}
            </if>
            <if test="conditionParamRef.areaCodes == null">
                ${_conditionType_} a.areaCodes is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('areaCodesList')">
            ${_conditionType_} a.areaCodes in
            <foreach collection="conditionParamRef.areaCodesList" open="(" close=")" index="index" item="item" separator=",">
                #{item}
            </foreach>
        </if>
        <if test="conditionParamRef.containsKey('status')">
            <if test="conditionParamRef.status != null ">
                ${_conditionType_} a.status = #{${_conditionParam_}.status}
            </if>
            <if test="conditionParamRef.status == null">
                ${_conditionType_} a.status is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('statusList')">
            ${_conditionType_} a.status in
            <foreach collection="conditionParamRef.statusList" open="(" close=")" index="index" item="item" separator=",">
                #{item}
            </foreach>
        </if>
        <if test="conditionParamRef.containsKey('statusStart') and conditionParamRef.statusStart != null">
            ${_conditionType_} a.status <![CDATA[ >= ]]> #{${_conditionParam_}.statusStart}
        </if>
        <if test="conditionParamRef.containsKey('statusEnd') and conditionParamRef.statusEnd != null">
            ${_conditionType_} a.status <![CDATA[ <= ]]> #{${_conditionParam_}.statusEnd}
        </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')">
            ${_conditionType_} a.createUserId in
            <foreach collection="conditionParamRef.createUserIdList" 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('createUserName')">
            <if test="conditionParamRef.createUserName != null and conditionParamRef.createUserName != ''">
                ${_conditionType_} a.createUserName like #{${_conditionParam_}.createUserName}
            </if>
            <if test="conditionParamRef.createUserName == null">
                ${_conditionType_} a.createUserName is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('createUserNameList')">
            ${_conditionType_} a.createUserName in
            <foreach collection="conditionParamRef.createUserNameList" open="(" close=")" index="index" item="item" separator=",">
                #{item}
            </foreach>
        </if>

        <if test="conditionParamRef.containsKey('lastLoginTime')">
            <if test="conditionParamRef.lastLoginTime != null ">
                ${_conditionType_} a.lastLoginTime = #{${_conditionParam_}.lastLoginTime}
            </if>
            <if test="conditionParamRef.lastLoginTime == null">
                ${_conditionType_} a.lastLoginTime is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('lastLoginTimeStart') and conditionParamRef.lastLoginTimeStart != null and conditionParamRef.lastLoginTimeStart!=''">
            ${_conditionType_} a.lastLoginTime <![CDATA[ >= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.lastLoginTimeStart},' 00:00:00'),19),'%Y-%m-%d %k:%i:%s')
        </if>
        <if test="conditionParamRef.containsKey('lastLoginTimeEnd') and conditionParamRef.lastLoginTimeEnd != null and conditionParamRef.lastLoginTimeEnd!=''">
            ${_conditionType_} a.lastLoginTime <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.lastLoginTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s')
        </if>

        <if test="conditionParamRef.containsKey('lastLoginAddress')">
            <if test="conditionParamRef.lastLoginAddress != null and conditionParamRef.lastLoginAddress != ''">
                ${_conditionType_} a.lastLoginAddress like #{${_conditionParam_}.lastLoginAddress}
            </if>
            <if test="conditionParamRef.lastLoginAddress == null">
                ${_conditionType_} a.lastLoginAddress is null
            </if>
        </if>
        <if test="conditionParamRef.containsKey('lastLoginAddressList')">
            ${_conditionType_} a.lastLoginAddress in
            <foreach collection="conditionParamRef.lastLoginAddressList" 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('loginName')">
                    a.loginName
                    <if test='orderCol.loginName != null and "DESC".equalsIgnoreCase(orderCol.loginName)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('loginPwd')">
                    a.loginPwd
                    <if test='orderCol.loginPwd != null and "DESC".equalsIgnoreCase(orderCol.loginPwd)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('loginLimitAddress')">
                    a.loginLimitAddress
                    <if test='orderCol.loginLimitAddress != null and "DESC".equalsIgnoreCase(orderCol.loginLimitAddress)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('realName')">
                    a.realName
                    <if test='orderCol.realName != null and "DESC".equalsIgnoreCase(orderCol.realName)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('mobile')">
                    a.mobile
                    <if test='orderCol.mobile != null and "DESC".equalsIgnoreCase(orderCol.mobile)'>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('email')">
                    a.email
                    <if test='orderCol.email != null and "DESC".equalsIgnoreCase(orderCol.email)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('qq')">
                    a.qq
                    <if test='orderCol.qq != null and "DESC".equalsIgnoreCase(orderCol.qq)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('userType')">
                    a.userType
                    <if test='orderCol.userType != null and "DESC".equalsIgnoreCase(orderCol.userType)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('siteIds')">
                    a.siteIds
                    <if test='orderCol.siteIds != null and "DESC".equalsIgnoreCase(orderCol.siteIds)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('areaCodes')">
                    a.areaCodes
                    <if test='orderCol.areaCodes != null and "DESC".equalsIgnoreCase(orderCol.areaCodes)'>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('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('createUserName')">
                    a.createUserName
                    <if test='orderCol.createUserName != null and "DESC".equalsIgnoreCase(orderCol.createUserName)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('lastLoginTime')">
                    a.lastLoginTime
                    <if test='orderCol.lastLoginTime != null and "DESC".equalsIgnoreCase(orderCol.lastLoginTime)'>DESC</if>
                    ,
                </if>
                <if test="orderCol.containsKey('lastLoginAddress')">
                    a.lastLoginAddress
                    <if test='orderCol.lastLoginAddress != null and "DESC".equalsIgnoreCase(orderCol.lastLoginAddress)'>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>