<?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.notice.dao.ibatis.NoticeDaoImpl">

    <!-- 字段和属性映射 -->
    <resultMap type="NoticeEntity" id="NoticeEntity-Map">
            <id  property="id" column="id" />
            <result property="title" column="title" />
            <result property="noticeType" column="noticeType" />
            <result property="pubDeptId" column="pubDeptId" />
            <result property="pubDeptName" column="pubDeptName" />
            <result property="viewPersion" column="viewPersion" />
            <result property="top" column="top" />
            <result property="readRequest" column="readRequest" />
            <result property="noticeContent" column="noticeContent" />
            <result property="filePath" column="filePath" />
            <result property="fileName" column="fileName" />
            <result property="remark" column="remark" />
            <result property="createUserId" column="createUserId" />
            <result property="createTime" column="createTime" />
            <result property="updateUserId" column="updateUserId" />
            <result property="updateTime" column="updateTime" />
            
    </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('title') or colPickMode == 1 and data.containsKey('title')))">
                    a.title,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('noticeType') or colPickMode == 1 and data.containsKey('noticeType')))">
                    a.noticeType,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('pubDeptId') or colPickMode == 1 and data.containsKey('pubDeptId')))">
                    a.pubDeptId,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('pubDeptName') or colPickMode == 1 and data.containsKey('pubDeptName')))">
                    a.pubDeptName,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('viewPersion') or colPickMode == 1 and data.containsKey('viewPersion')))">
                    a.viewPersion,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('top') or colPickMode == 1 and data.containsKey('top')))">
                    a.top,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('readRequest') or colPickMode == 1 and data.containsKey('readRequest')))">
                    a.readRequest,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('noticeContent') or colPickMode == 1 and data.containsKey('noticeContent')))">
                    a.noticeContent,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('filePath') or colPickMode == 1 and data.containsKey('filePath')))">
                    a.filePath,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('fileName') or colPickMode == 1 and data.containsKey('fileName')))">
                    a.fileName,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('remark') or colPickMode == 1 and data.containsKey('remark')))">
                    a.remark,
                </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('createTime') or colPickMode == 1 and data.containsKey('createTime')))">
                    a.createTime,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('updateUserId') or colPickMode == 1 and data.containsKey('updateUserId')))">
                    a.updateUserId,
                </if>
                <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('updateTime') or colPickMode == 1 and data.containsKey('updateTime')))">
                    a.updateTime,
                </if>
        </trim>
    </sql>
    <!-- 新增 区分主键自增加还是业务插入 -->
    <insert id="insert" parameterType="NoticeEntity"  useGeneratedKeys="true" keyProperty="id">
        insert into mortals_xhx_notice
        (title,noticeType,pubDeptId,pubDeptName,viewPersion,top,readRequest,noticeContent,filePath,fileName,remark,createUserId,createTime,updateUserId,updateTime)
        VALUES
        (#{title},#{noticeType},#{pubDeptId},#{pubDeptName},#{viewPersion},#{top},#{readRequest},#{noticeContent},#{filePath},#{fileName},#{remark},#{createUserId},#{createTime},#{updateUserId},#{updateTime})
    </insert>

    <!-- 批量新增 -->
    <insert id="insertBatch" parameterType="paramDto">
        insert into mortals_xhx_notice
        (title,noticeType,pubDeptId,pubDeptName,viewPersion,top,readRequest,noticeContent,filePath,fileName,remark,createUserId,createTime,updateUserId,updateTime)
        VALUES
        <foreach collection="data.dataList" item="item" index="index" separator="," >
            (#{item.title},#{item.noticeType},#{item.pubDeptId},#{item.pubDeptName},#{item.viewPersion},#{item.top},#{item.readRequest},#{item.noticeContent},#{item.filePath},#{item.fileName},#{item.remark},#{item.createUserId},#{item.createTime},#{item.updateUserId},#{item.updateTime})
        </foreach>
    </insert>


    <!-- 根据ParamDto更新 -->
    <update id="update" parameterType="paramDto">
        update mortals_xhx_notice as a
        set
        <trim suffixOverrides="," suffix="">
            <if test="(colPickMode==0 and data.containsKey('title')) or (colPickMode==1 and !data.containsKey('title'))">
                a.title=#{data.title},
            </if>
            <if test="(colPickMode==0 and data.containsKey('noticeType')) or (colPickMode==1 and !data.containsKey('noticeType'))">
                a.noticeType=#{data.noticeType},
            </if>
            <if test="(colPickMode==0 and data.containsKey('noticeTypeIncrement')) or (colPickMode==1 and !data.containsKey('noticeTypeIncrement'))">
                a.noticeType=ifnull(a.noticeType,0) + #{data.noticeTypeIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('pubDeptId')) or (colPickMode==1 and !data.containsKey('pubDeptId'))">
                a.pubDeptId=#{data.pubDeptId},
            </if>
            <if test="(colPickMode==0 and data.containsKey('pubDeptIdIncrement')) or (colPickMode==1 and !data.containsKey('pubDeptIdIncrement'))">
                a.pubDeptId=ifnull(a.pubDeptId,0) + #{data.pubDeptIdIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('pubDeptName')) or (colPickMode==1 and !data.containsKey('pubDeptName'))">
                a.pubDeptName=#{data.pubDeptName},
            </if>
            <if test="(colPickMode==0 and data.containsKey('viewPersion')) or (colPickMode==1 and !data.containsKey('viewPersion'))">
                a.viewPersion=#{data.viewPersion},
            </if>
            <if test="(colPickMode==0 and data.containsKey('viewPersionIncrement')) or (colPickMode==1 and !data.containsKey('viewPersionIncrement'))">
                a.viewPersion=ifnull(a.viewPersion,0) + #{data.viewPersionIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('top')) or (colPickMode==1 and !data.containsKey('top'))">
                a.top=#{data.top},
            </if>
            <if test="(colPickMode==0 and data.containsKey('topIncrement')) or (colPickMode==1 and !data.containsKey('topIncrement'))">
                a.top=ifnull(a.top,0) + #{data.topIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('readRequest')) or (colPickMode==1 and !data.containsKey('readRequest'))">
                a.readRequest=#{data.readRequest},
            </if>
            <if test="(colPickMode==0 and data.containsKey('readRequestIncrement')) or (colPickMode==1 and !data.containsKey('readRequestIncrement'))">
                a.readRequest=ifnull(a.readRequest,0) + #{data.readRequestIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('noticeContent')) or (colPickMode==1 and !data.containsKey('noticeContent'))">
                a.noticeContent=#{data.noticeContent},
            </if>
            <if test="(colPickMode==0 and data.containsKey('filePath')) or (colPickMode==1 and !data.containsKey('filePath'))">
                a.filePath=#{data.filePath},
            </if>
            <if test="(colPickMode==0 and data.containsKey('fileName')) or (colPickMode==1 and !data.containsKey('fileName'))">
                a.fileName=#{data.fileName},
            </if>
            <if test="(colPickMode==0 and data.containsKey('remark')) or (colPickMode==1 and !data.containsKey('remark'))">
                a.remark=#{data.remark},
            </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('createTime')) or (colPickMode==1 and !data.containsKey('createTime'))">
                a.createTime=#{data.createTime},
            </if>
            <if test="(colPickMode==0 and data.containsKey('updateUserId')) or (colPickMode==1 and !data.containsKey('updateUserId'))">
                a.updateUserId=#{data.updateUserId},
            </if>
            <if test="(colPickMode==0 and data.containsKey('updateUserIdIncrement')) or (colPickMode==1 and !data.containsKey('updateUserIdIncrement'))">
                a.updateUserId=ifnull(a.updateUserId,0) + #{data.updateUserIdIncrement},
            </if>
            <if test="(colPickMode==0 and data.containsKey('updateTime')) or (colPickMode==1 and !data.containsKey('updateTime'))">
                a.updateTime=#{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_xhx_notice as a
        <trim prefix="set" suffixOverrides=",">
                <trim prefix="title=(case" suffix="ELSE title end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('title')) or (colPickMode==1 and !item.containsKey('title'))">
                            when a.id=#{item.id} then #{item.title}
                        </if>
                    </foreach>
                </trim>
                        <trim prefix="noticeType=(case" suffix="ELSE noticeType end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('noticeType')) or (colPickMode==1 and !item.containsKey('noticeType'))">
                                        when a.id=#{item.id} then #{item.noticeType}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('noticeTypeIncrement')) or (colPickMode==1 and !item.containsKey('noticeTypeIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.noticeType,0) + #{item.noticeTypeIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                        <trim prefix="pubDeptId=(case" suffix="ELSE pubDeptId end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('pubDeptId')) or (colPickMode==1 and !item.containsKey('pubDeptId'))">
                                        when a.id=#{item.id} then #{item.pubDeptId}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('pubDeptIdIncrement')) or (colPickMode==1 and !item.containsKey('pubDeptIdIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.pubDeptId,0) + #{item.pubDeptIdIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                <trim prefix="pubDeptName=(case" suffix="ELSE pubDeptName end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('pubDeptName')) or (colPickMode==1 and !item.containsKey('pubDeptName'))">
                            when a.id=#{item.id} then #{item.pubDeptName}
                        </if>
                    </foreach>
                </trim>
                        <trim prefix="viewPersion=(case" suffix="ELSE viewPersion end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('viewPersion')) or (colPickMode==1 and !item.containsKey('viewPersion'))">
                                        when a.id=#{item.id} then #{item.viewPersion}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('viewPersionIncrement')) or (colPickMode==1 and !item.containsKey('viewPersionIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.viewPersion,0) + #{item.viewPersionIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                        <trim prefix="top=(case" suffix="ELSE top end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('top')) or (colPickMode==1 and !item.containsKey('top'))">
                                        when a.id=#{item.id} then #{item.top}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('topIncrement')) or (colPickMode==1 and !item.containsKey('topIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.top,0) + #{item.topIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                        <trim prefix="readRequest=(case" suffix="ELSE readRequest end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('readRequest')) or (colPickMode==1 and !item.containsKey('readRequest'))">
                                        when a.id=#{item.id} then #{item.readRequest}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('readRequestIncrement')) or (colPickMode==1 and !item.containsKey('readRequestIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.readRequest,0) + #{item.readRequestIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                <trim prefix="noticeContent=(case" suffix="ELSE noticeContent end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('noticeContent')) or (colPickMode==1 and !item.containsKey('noticeContent'))">
                            when a.id=#{item.id} then #{item.noticeContent}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="filePath=(case" suffix="ELSE filePath end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('filePath')) or (colPickMode==1 and !item.containsKey('filePath'))">
                            when a.id=#{item.id} then #{item.filePath}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="fileName=(case" suffix="ELSE fileName end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('fileName')) or (colPickMode==1 and !item.containsKey('fileName'))">
                            when a.id=#{item.id} then #{item.fileName}
                        </if>
                    </foreach>
                </trim>
                <trim prefix="remark=(case" suffix="ELSE remark end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('remark')) or (colPickMode==1 and !item.containsKey('remark'))">
                            when a.id=#{item.id} then #{item.remark}
                        </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="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="updateUserId=(case" suffix="ELSE updateUserId end),">
                            <foreach collection="data.dataList" item="item" index="index" separator="" >
                                <choose>
                                    <when test="(colPickMode==0 and item.containsKey('updateUserId')) or (colPickMode==1 and !item.containsKey('updateUserId'))">
                                        when a.id=#{item.id} then #{item.updateUserId}
                                    </when>
                                    <when test="(colPickMode==0 and item.containsKey('updateUserIdIncrement')) or (colPickMode==1 and !item.containsKey('updateUserIdIncrement'))">
                                        when a.id=#{item.id} then ifnull(a.updateUserId,0) + #{item.updateUserIdIncrement}
                                    </when>
                                </choose>
                            </foreach>
                        </trim>
                <trim prefix="updateTime=(case" suffix="ELSE updateTime end),">
                    <foreach collection="data.dataList" item="item" index="index" separator="" >
                        <if test="(colPickMode==0 and item.containsKey('updateTime')) or (colPickMode==1 and !item.containsKey('updateTime'))">
                            when a.id=#{item.id} then #{item.updateTime}
                        </if>
                    </foreach>
                </trim>
        </trim>
        where id in
        <foreach collection="data.dataList" item="item" index="index" open="(" separator="," close=")">
            #{item.id}
        </foreach>
    </update>
    <!-- 根据主健查询 -->
    <select id="getByKey" parameterType="paramDto" resultMap="NoticeEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_notice as a
        where a.id=#{condition.id}
    </select>
    <!-- 根据主健删除 -->
    <delete id="deleteByKey" parameterType="paramDto">
        delete a.* from mortals_xhx_notice as a where a.id=#{condition.id}
    </delete>
    <!-- 根据主健删除一批,针对单一主健有效 -->
    <delete id="deleteByKeys">
        delete from mortals_xhx_notice where id in
        <foreach collection="array" item="item" index="index" open="(" separator="," close=")">
            #{item}
        </foreach>
    </delete>
    <!-- 根据主健列表删除一批,针对单一主健有效 -->
    <delete id="deleteByKeyList">
        delete from mortals_xhx_notice where id in
        <foreach collection="list" item="item" index="index" open="(" separator="," close=")">
            #{item}
        </foreach>
    </delete>

    <!-- 根据对象列表删除一批,针对单一主健有效 -->
    <delete id="deleteByEntityList">
        delete from mortals_xhx_notice where id in
        <foreach collection="list" item="item" index="index" open="(" separator="," close=")">
            #{item.id}
        </foreach>
    </delete>
    <!-- 根据paramDto删除一批 -->
    <delete id="deleteByMap" parameterType="paramDto">
        delete a.* from mortals_xhx_notice as a
        <trim suffixOverrides="where" suffix="">
            where
            <trim prefixOverrides="and" prefix="">
                <include refid="_condition_"/>
            </trim>
        </trim>
    </delete>
    <!-- 获取列表 -->
    <select id="getList" parameterType="paramDto" resultMap="NoticeEntity-Map">
        select <include refid="_columns"/>
        from mortals_xhx_notice 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_notice 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('idNotList')">
                ${_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('title')">
                <if test="conditionParamRef.title != null and conditionParamRef.title != ''">
                    ${_conditionType_} a.title like #{${_conditionParam_}.title}
                </if>
                <if test="conditionParamRef.title == null">
                    ${_conditionType_} a.title is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('titleList')">
                ${_conditionType_} a.title in
                <foreach collection="conditionParamRef.titleList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('titleNotList')">
                ${_conditionType_} a.title not in
                <foreach collection="conditionParamRef.titleNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('noticeType')">
                <if test="conditionParamRef.noticeType != null ">
                    ${_conditionType_} a.noticeType = #{${_conditionParam_}.noticeType}
                </if>
                <if test="conditionParamRef.noticeType == null">
                    ${_conditionType_} a.noticeType is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('noticeTypeList')">
                ${_conditionType_} a.noticeType in
                <foreach collection="conditionParamRef.noticeTypeList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('noticeTypeNotList')">
                ${_conditionType_} a.noticeType not in
                <foreach collection="conditionParamRef.noticeTypeNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('noticeTypeStart') and conditionParamRef.noticeTypeStart != null">
                ${_conditionType_} a.noticeType <![CDATA[ >= ]]> #{${_conditionParam_}.noticeTypeStart}
            </if>
            <if test="conditionParamRef.containsKey('noticeTypeEnd') and conditionParamRef.noticeTypeEnd != null">
                ${_conditionType_} a.noticeType <![CDATA[ <= ]]> #{${_conditionParam_}.noticeTypeEnd}
            </if>

            <if test="conditionParamRef.containsKey('pubDeptId')">
                <if test="conditionParamRef.pubDeptId != null ">
                    ${_conditionType_} a.pubDeptId = #{${_conditionParam_}.pubDeptId}
                </if>
                <if test="conditionParamRef.pubDeptId == null">
                    ${_conditionType_} a.pubDeptId is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('pubDeptIdList')">
                ${_conditionType_} a.pubDeptId in
                <foreach collection="conditionParamRef.pubDeptIdList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('pubDeptIdNotList')">
                ${_conditionType_} a.pubDeptId not in
                <foreach collection="conditionParamRef.pubDeptIdNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('pubDeptIdStart') and conditionParamRef.pubDeptIdStart != null">
                ${_conditionType_} a.pubDeptId <![CDATA[ >= ]]> #{${_conditionParam_}.pubDeptIdStart}
            </if>
            <if test="conditionParamRef.containsKey('pubDeptIdEnd') and conditionParamRef.pubDeptIdEnd != null">
                ${_conditionType_} a.pubDeptId <![CDATA[ <= ]]> #{${_conditionParam_}.pubDeptIdEnd}
            </if>


            <if test="conditionParamRef.containsKey('pubDeptName')">
                <if test="conditionParamRef.pubDeptName != null and conditionParamRef.pubDeptName != ''">
                    ${_conditionType_} a.pubDeptName like #{${_conditionParam_}.pubDeptName}
                </if>
                <if test="conditionParamRef.pubDeptName == null">
                    ${_conditionType_} a.pubDeptName is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('pubDeptNameList')">
                ${_conditionType_} a.pubDeptName in
                <foreach collection="conditionParamRef.pubDeptNameList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('pubDeptNameNotList')">
                ${_conditionType_} a.pubDeptName not in
                <foreach collection="conditionParamRef.pubDeptNameNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('viewPersion')">
                <if test="conditionParamRef.viewPersion != null ">
                    ${_conditionType_} a.viewPersion = #{${_conditionParam_}.viewPersion}
                </if>
                <if test="conditionParamRef.viewPersion == null">
                    ${_conditionType_} a.viewPersion is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('viewPersionList')">
                ${_conditionType_} a.viewPersion in
                <foreach collection="conditionParamRef.viewPersionList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('viewPersionNotList')">
                ${_conditionType_} a.viewPersion not in
                <foreach collection="conditionParamRef.viewPersionNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('viewPersionStart') and conditionParamRef.viewPersionStart != null">
                ${_conditionType_} a.viewPersion <![CDATA[ >= ]]> #{${_conditionParam_}.viewPersionStart}
            </if>
            <if test="conditionParamRef.containsKey('viewPersionEnd') and conditionParamRef.viewPersionEnd != null">
                ${_conditionType_} a.viewPersion <![CDATA[ <= ]]> #{${_conditionParam_}.viewPersionEnd}
            </if>

            <if test="conditionParamRef.containsKey('top')">
                <if test="conditionParamRef.top != null ">
                    ${_conditionType_} a.top = #{${_conditionParam_}.top}
                </if>
                <if test="conditionParamRef.top == null">
                    ${_conditionType_} a.top is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('topList')">
                ${_conditionType_} a.top in
                <foreach collection="conditionParamRef.topList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('topNotList')">
                ${_conditionType_} a.top not in
                <foreach collection="conditionParamRef.topNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('topStart') and conditionParamRef.topStart != null">
                ${_conditionType_} a.top <![CDATA[ >= ]]> #{${_conditionParam_}.topStart}
            </if>
            <if test="conditionParamRef.containsKey('topEnd') and conditionParamRef.topEnd != null">
                ${_conditionType_} a.top <![CDATA[ <= ]]> #{${_conditionParam_}.topEnd}
            </if>

            <if test="conditionParamRef.containsKey('readRequest')">
                <if test="conditionParamRef.readRequest != null ">
                    ${_conditionType_} a.readRequest = #{${_conditionParam_}.readRequest}
                </if>
                <if test="conditionParamRef.readRequest == null">
                    ${_conditionType_} a.readRequest is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('readRequestList')">
                ${_conditionType_} a.readRequest in
                <foreach collection="conditionParamRef.readRequestList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('readRequestNotList')">
                ${_conditionType_} a.readRequest not in
                <foreach collection="conditionParamRef.readRequestNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('readRequestStart') and conditionParamRef.readRequestStart != null">
                ${_conditionType_} a.readRequest <![CDATA[ >= ]]> #{${_conditionParam_}.readRequestStart}
            </if>
            <if test="conditionParamRef.containsKey('readRequestEnd') and conditionParamRef.readRequestEnd != null">
                ${_conditionType_} a.readRequest <![CDATA[ <= ]]> #{${_conditionParam_}.readRequestEnd}
            </if>


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

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

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

            <if test="conditionParamRef.containsKey('remark')">
                <if test="conditionParamRef.remark != null and conditionParamRef.remark != ''">
                    ${_conditionType_} a.remark like #{${_conditionParam_}.remark}
                </if>
                <if test="conditionParamRef.remark == null">
                    ${_conditionType_} a.remark is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('remarkList')">
                ${_conditionType_} a.remark in
                <foreach collection="conditionParamRef.remarkList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('remarkNotList')">
                ${_conditionType_} a.remark not in
                <foreach collection="conditionParamRef.remarkNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </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('createUserIdNotList')">
                ${_conditionType_} a.createUserId not in
                <foreach collection="conditionParamRef.createUserIdNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('createUserIdStart') and conditionParamRef.createUserIdStart != null">
                ${_conditionType_} a.createUserId <![CDATA[ >= ]]> #{${_conditionParam_}.createUserIdStart}
            </if>
            <if test="conditionParamRef.containsKey('createUserIdEnd') and conditionParamRef.createUserIdEnd != null">
                ${_conditionType_} a.createUserId <![CDATA[ <= ]]> #{${_conditionParam_}.createUserIdEnd}
            </if>


            <if test="conditionParamRef.containsKey('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('updateUserId')">
                <if test="conditionParamRef.updateUserId != null ">
                    ${_conditionType_} a.updateUserId = #{${_conditionParam_}.updateUserId}
                </if>
                <if test="conditionParamRef.updateUserId == null">
                    ${_conditionType_} a.updateUserId is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdList')">
                ${_conditionType_} a.updateUserId in
                <foreach collection="conditionParamRef.updateUserIdList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdNotList')">
                ${_conditionType_} a.updateUserId not in
                <foreach collection="conditionParamRef.updateUserIdNotList" open="(" close=")" index="index" item="item" separator=",">
                    #{item}
                </foreach>
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdStart') and conditionParamRef.updateUserIdStart != null">
                ${_conditionType_} a.updateUserId <![CDATA[ >= ]]> #{${_conditionParam_}.updateUserIdStart}
            </if>
            <if test="conditionParamRef.containsKey('updateUserIdEnd') and conditionParamRef.updateUserIdEnd != null">
                ${_conditionType_} a.updateUserId <![CDATA[ <= ]]> #{${_conditionParam_}.updateUserIdEnd}
            </if>


            <if test="conditionParamRef.containsKey('updateTime')">
                <if test="conditionParamRef.updateTime != null ">
                    ${_conditionType_} a.updateTime = #{${_conditionParam_}.updateTime}
                </if>
                <if test="conditionParamRef.updateTime == null">
                    ${_conditionType_} a.updateTime is null
                </if>
            </if>
            <if test="conditionParamRef.containsKey('updateTimeStart') and conditionParamRef.updateTimeStart != null and conditionParamRef.updateTimeStart!=''">
                ${_conditionType_} a.updateTime <![CDATA[ >= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.updateTimeStart},' 00:00:00'),19),'%Y-%m-%d %k:%i:%s')
            </if>
            <if test="conditionParamRef.containsKey('updateTimeEnd') and conditionParamRef.updateTimeEnd != null and conditionParamRef.updateTimeEnd!=''">
                ${_conditionType_} a.updateTime <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.updateTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s')
            </if>
    </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('title')">
                        a.title
                        <if test='orderCol.title != null and "DESC".equalsIgnoreCase(orderCol.title)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('noticeType')">
                        a.noticeType
                        <if test='orderCol.noticeType != null and "DESC".equalsIgnoreCase(orderCol.noticeType)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('pubDeptId')">
                        a.pubDeptId
                        <if test='orderCol.pubDeptId != null and "DESC".equalsIgnoreCase(orderCol.pubDeptId)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('pubDeptName')">
                        a.pubDeptName
                        <if test='orderCol.pubDeptName != null and "DESC".equalsIgnoreCase(orderCol.pubDeptName)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('viewPersion')">
                        a.viewPersion
                        <if test='orderCol.viewPersion != null and "DESC".equalsIgnoreCase(orderCol.viewPersion)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('top')">
                        a.top
                        <if test='orderCol.top != null and "DESC".equalsIgnoreCase(orderCol.top)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('readRequest')">
                        a.readRequest
                        <if test='orderCol.readRequest != null and "DESC".equalsIgnoreCase(orderCol.readRequest)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('noticeContent')">
                        a.noticeContent
                        <if test='orderCol.noticeContent != null and "DESC".equalsIgnoreCase(orderCol.noticeContent)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('filePath')">
                        a.filePath
                        <if test='orderCol.filePath != null and "DESC".equalsIgnoreCase(orderCol.filePath)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('fileName')">
                        a.fileName
                        <if test='orderCol.fileName != null and "DESC".equalsIgnoreCase(orderCol.fileName)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('remark')">
                        a.remark
                        <if test='orderCol.remark != null and "DESC".equalsIgnoreCase(orderCol.remark)'>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('createTime')">
                        a.createTime
                        <if test='orderCol.createTime != null and "DESC".equalsIgnoreCase(orderCol.createTime)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('updateUserId')">
                        a.updateUserId
                        <if test='orderCol.updateUserId != null and "DESC".equalsIgnoreCase(orderCol.updateUserId)'>DESC</if>
                        ,
                    </if>
                    <if test="orderCol.containsKey('updateTime')">
                        a.updateTime
                        <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>