<?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>