<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "mybatis-3-mapper.dtd"> <mapper namespace="com.mortals.xhx.module.yth.dao.ibatis.YthWarrntsetDaoImpl"> <!-- 字段和属性映射 --> <resultMap type="YthWarrntsetEntity" id="YthWarrntsetEntity-Map"> <result property="id" column="id" /> <result property="matterid" column="matterid" /> <result property="lawName" column="lawName" /> <result property="lawType" column="lawType" /> <result property="referenceNum" column="referenceNum" /> <result property="clause" column="clause" /> <result property="clauseContent" column="clauseContent" /> <result property="sort" column="sort" /> <result property="createTime" column="createTime" /> <result property="createUser" column="createUser" /> </resultMap> <!-- 表所有列 --> <sql id="_columns"> <trim suffixOverrides="," suffix=""> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('id') or colPickMode == 1 and data.containsKey('id')))"> a.id as id, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('matterid') or colPickMode == 1 and data.containsKey('matterid')))"> a.matterid as matterid, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('lawName') or colPickMode == 1 and data.containsKey('lawName')))"> a.lawName as lawName, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('lawType') or colPickMode == 1 and data.containsKey('lawType')))"> a.lawType as lawType, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('referenceNum') or colPickMode == 1 and data.containsKey('referenceNum')))"> a.referenceNum as referenceNum, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('clause') or colPickMode == 1 and data.containsKey('clause')))"> a.clause as clause, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('clauseContent') or colPickMode == 1 and data.containsKey('clauseContent')))"> a.clauseContent as clauseContent, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('sort') or colPickMode == 1 and data.containsKey('sort')))"> a.sort as sort, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createTime') or colPickMode == 1 and data.containsKey('createTime')))"> a.createTime as createTime, </if> <if test="(data == null) or (data != null and ( colPickMode == 0 and !data.containsKey('createUser') or colPickMode == 1 and data.containsKey('createUser')))"> a.createUser as createUser, </if> </trim> </sql> <!-- 新增 --> <insert id="insert" parameterType="YthWarrntsetEntity" useGeneratedKeys="true" keyProperty="id"> insert into mortals_xhx_yth_warrntset (matterid,lawName,lawType,referenceNum,clause,clauseContent,sort,createTime,createUser) VALUES (#{matterid},#{lawName},#{lawType},#{referenceNum},#{clause},#{clauseContent},#{sort},#{createTime},#{createUser}) </insert> <!-- 批量新增 --> <insert id="insertBatch" parameterType="paramDto"> insert into mortals_xhx_yth_warrntset (matterid,lawName,lawType,referenceNum,clause,clauseContent,sort,createTime,createUser) VALUES <foreach collection="data.dataList" item="item" index="index" separator="," > (#{item.matterid},#{item.lawName},#{item.lawType},#{item.referenceNum},#{item.clause},#{item.clauseContent},#{item.sort},#{item.createTime},#{item.createUser}) </foreach> </insert> <!-- 根据ParamDto更新 --> <update id="update" parameterType="paramDto"> update mortals_xhx_yth_warrntset as a set <trim suffixOverrides="," suffix=""> <if test="(colPickMode==0 and data.containsKey('matterid')) or (colPickMode==1 and !data.containsKey('matterid'))"> a.matterid=#{data.matterid}, </if> <if test="(colPickMode==0 and data.containsKey('matteridIncrement')) or (colPickMode==1 and !data.containsKey('matteridIncrement'))"> a.matterid=ifnull(a.matterid,0) + #{data.matteridIncrement}, </if> <if test="(colPickMode==0 and data.containsKey('lawName')) or (colPickMode==1 and !data.containsKey('lawName'))"> a.lawName=#{data.lawName}, </if> <if test="(colPickMode==0 and data.containsKey('lawType')) or (colPickMode==1 and !data.containsKey('lawType'))"> a.lawType=#{data.lawType}, </if> <if test="(colPickMode==0 and data.containsKey('lawTypeIncrement')) or (colPickMode==1 and !data.containsKey('lawTypeIncrement'))"> a.lawType=ifnull(a.lawType,0) + #{data.lawTypeIncrement}, </if> <if test="(colPickMode==0 and data.containsKey('referenceNum')) or (colPickMode==1 and !data.containsKey('referenceNum'))"> a.referenceNum=#{data.referenceNum}, </if> <if test="(colPickMode==0 and data.containsKey('clause')) or (colPickMode==1 and !data.containsKey('clause'))"> a.clause=#{data.clause}, </if> <if test="(colPickMode==0 and data.containsKey('clauseContent')) or (colPickMode==1 and !data.containsKey('clauseContent'))"> a.clauseContent=#{data.clauseContent}, </if> <if test="(colPickMode==0 and data.containsKey('sort')) or (colPickMode==1 and !data.containsKey('sort'))"> a.sort=#{data.sort}, </if> <if test="(colPickMode==0 and data.containsKey('sortIncrement')) or (colPickMode==1 and !data.containsKey('sortIncrement'))"> a.sort=ifnull(a.sort,0) + #{data.sortIncrement}, </if> <if test="(colPickMode==0 and data.containsKey('createTime')) or (colPickMode==1 and !data.containsKey('createTime'))"> a.createTime=#{data.createTime}, </if> <if test="(colPickMode==0 and data.containsKey('createUser')) or (colPickMode==1 and !data.containsKey('createUser'))"> a.createUser=#{data.createUser}, </if> </trim> <trim suffixOverrides="where" suffix=""> where <trim prefixOverrides="and" prefix=""> <include refid="_condition_"/> </trim> </trim> </update> <!-- 批量更新 --> <update id="updateBatch" parameterType="paramDto"> update mortals_xhx_yth_warrntset as a <trim prefix="set" suffixOverrides=","> <trim prefix="matterid=(case" suffix="ELSE matterid end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <choose> <when test="(colPickMode==0 and item.containsKey('matterid')) or (colPickMode==1 and !item.containsKey('matterid'))"> when a.id=#{item.id} then #{item.matterid} </when> <when test="(colPickMode==0 and item.containsKey('matteridIncrement')) or (colPickMode==1 and !item.containsKey('matteridIncrement'))"> when a.id=#{item.id} then ifnull(a.matterid,0) + #{item.matteridIncrement} </when> </choose> </foreach> </trim> <trim prefix="lawName=(case" suffix="ELSE lawName end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('lawName')) or (colPickMode==1 and !item.containsKey('lawName'))"> when a.id=#{item.id} then #{item.lawName} </if> </foreach> </trim> <trim prefix="lawType=(case" suffix="ELSE lawType end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <choose> <when test="(colPickMode==0 and item.containsKey('lawType')) or (colPickMode==1 and !item.containsKey('lawType'))"> when a.id=#{item.id} then #{item.lawType} </when> <when test="(colPickMode==0 and item.containsKey('lawTypeIncrement')) or (colPickMode==1 and !item.containsKey('lawTypeIncrement'))"> when a.id=#{item.id} then ifnull(a.lawType,0) + #{item.lawTypeIncrement} </when> </choose> </foreach> </trim> <trim prefix="referenceNum=(case" suffix="ELSE referenceNum end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('referenceNum')) or (colPickMode==1 and !item.containsKey('referenceNum'))"> when a.id=#{item.id} then #{item.referenceNum} </if> </foreach> </trim> <trim prefix="clause=(case" suffix="ELSE clause end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('clause')) or (colPickMode==1 and !item.containsKey('clause'))"> when a.id=#{item.id} then #{item.clause} </if> </foreach> </trim> <trim prefix="clauseContent=(case" suffix="ELSE clauseContent end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('clauseContent')) or (colPickMode==1 and !item.containsKey('clauseContent'))"> when a.id=#{item.id} then #{item.clauseContent} </if> </foreach> </trim> <trim prefix="sort=(case" suffix="ELSE sort end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <choose> <when test="(colPickMode==0 and item.containsKey('sort')) or (colPickMode==1 and !item.containsKey('sort'))"> when a.id=#{item.id} then #{item.sort} </when> <when test="(colPickMode==0 and item.containsKey('sortIncrement')) or (colPickMode==1 and !item.containsKey('sortIncrement'))"> when a.id=#{item.id} then ifnull(a.sort,0) + #{item.sortIncrement} </when> </choose> </foreach> </trim> <trim prefix="createTime=(case" suffix="ELSE createTime end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('createTime')) or (colPickMode==1 and !item.containsKey('createTime'))"> when a.id=#{item.id} then #{item.createTime} </if> </foreach> </trim> <trim prefix="createUser=(case" suffix="ELSE createUser end),"> <foreach collection="data.dataList" item="item" index="index" separator="" > <if test="(colPickMode==0 and item.containsKey('createUser')) or (colPickMode==1 and !item.containsKey('createUser'))"> when a.id=#{item.id} then #{item.createUser} </if> </foreach> </trim> </trim> where id in <foreach collection="data.dataList" item="item" index="index" open="(" separator="," close=")"> #{item.id} </foreach> </update> <!-- 根据主健查询 --> <select id="getByKey" parameterType="paramDto" resultMap="YthWarrntsetEntity-Map"> select <include refid="_columns"/> from mortals_xhx_yth_warrntset as a where a.id=#{condition.id} </select> <!-- 根据主健删除 --> <delete id="deleteByKey" parameterType="paramDto"> delete a.* from mortals_xhx_yth_warrntset as a where a.id=#{condition.id} </delete> <!-- 根据主健删除一批,针对单一主健有效 --> <delete id="deleteByKeys"> delete from mortals_xhx_yth_warrntset where id in <foreach collection="array" item="item" index="index" open="(" separator="," close=")"> #{item} </foreach> </delete> <!-- 根据paramDto删除一批 --> <delete id="deleteByMap" parameterType="paramDto"> delete a.* from mortals_xhx_yth_warrntset as a <trim suffixOverrides="where" suffix=""> where <trim prefixOverrides="and" prefix=""> <include refid="_condition_"/> </trim> </trim> </delete> <!-- 获取列表 --> <select id="getList" parameterType="paramDto" resultMap="YthWarrntsetEntity-Map"> select <include refid="_columns"/> from mortals_xhx_yth_warrntset as a <trim suffixOverrides="where" suffix=""> where <trim prefixOverrides="and" prefix=""> <include refid="_condition_"/> </trim> </trim> <include refid="_orderCols_"/> </select> <!-- 获取 --> <select id="getListCount" parameterType="paramDto" resultType="int"> select count(1) from mortals_xhx_yth_warrntset as a <trim suffixOverrides="where" suffix=""> where <trim prefixOverrides="and" prefix=""> <include refid="_condition_"/> </trim> </trim> </select> <!-- 条件映射 --> <sql id="_condition_"> <if test="condition != null and !condition.isEmpty()"> <!-- 条件映射-普通条件 --> <include refid="_condition_param_"> <property name="_conditionParam_" value="condition"/> <property name="_conditionType_" value="and"/> </include> <!-- 条件映射-集合之间使用AND,集合中元素使用OR-(list[0].1 or list[0].2) and (list[1].3 or list[1].4) --> <if test="condition.containsKey('andConditionList') and !condition.andConditionList.isEmpty()"> and <foreach collection="condition.andConditionList" open="(" close=")" index="index" item="andCondition" separator=" and "> <trim prefixOverrides="or" prefix="(" suffix=")"> <include refid="_condition_param_"> <property name="_conditionParam_" value="andCondition"/> <property name="_conditionType_" value="or"/> </include> </trim> </foreach> </if> <!-- 条件映射-集合之间使用OR,集合中元素使用AND-(list[0].1 and list[0].2) or (list[1].3 and list[1].4) --> <if test="condition.containsKey('orConditionList') and !condition.orConditionList.isEmpty()"> and <foreach collection="condition.orConditionList" open="(" close=")" index="index" item="orCondition" separator=" or "> <trim prefixOverrides="and" prefix="(" suffix=")"> <include refid="_condition_param_"> <property name="_conditionParam_" value="orCondition"/> <property name="_conditionType_" value="and"/> </include> </trim> </foreach> </if> </if> </sql> <!-- 条件映射-代参数 --> <sql id="_condition_param_"> <bind name="conditionParamRef" value="${_conditionParam_}"/> <if test="conditionParamRef.containsKey('id')"> <if test="conditionParamRef.id != null"> ${_conditionType_} a.id=#{${_conditionParam_}.id} </if> </if> <if test="conditionParamRef.containsKey('id')"> <if test="conditionParamRef.id != null "> ${_conditionType_} a.id = #{${_conditionParam_}.id} </if> <if test="conditionParamRef.id == null"> ${_conditionType_} a.id is null </if> </if> <if test="conditionParamRef.containsKey('idList')"> ${_conditionType_} a.id in <foreach collection="conditionParamRef.idList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('idStart') and conditionParamRef.idStart != null"> ${_conditionType_} a.id <![CDATA[ >= ]]> #{${_conditionParam_}.idStart} </if> <if test="conditionParamRef.containsKey('idEnd') and conditionParamRef.idEnd != null"> ${_conditionType_} a.id <![CDATA[ <= ]]> #{${_conditionParam_}.idEnd} </if> <if test="conditionParamRef.containsKey('matterid')"> <if test="conditionParamRef.matterid != null "> ${_conditionType_} a.matterid = #{${_conditionParam_}.matterid} </if> <if test="conditionParamRef.matterid == null"> ${_conditionType_} a.matterid is null </if> </if> <if test="conditionParamRef.containsKey('matteridList')"> ${_conditionType_} a.matterid in <foreach collection="conditionParamRef.matteridList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('matteridStart') and conditionParamRef.matteridStart != null"> ${_conditionType_} a.matterid <![CDATA[ >= ]]> #{${_conditionParam_}.matteridStart} </if> <if test="conditionParamRef.containsKey('matteridEnd') and conditionParamRef.matteridEnd != null"> ${_conditionType_} a.matterid <![CDATA[ <= ]]> #{${_conditionParam_}.matteridEnd} </if> <if test="conditionParamRef.containsKey('lawName')"> <if test="conditionParamRef.lawName != null and conditionParamRef.lawName != ''"> ${_conditionType_} a.lawName like #{${_conditionParam_}.lawName} </if> <if test="conditionParamRef.lawName == null"> ${_conditionType_} a.lawName is null </if> </if> <if test="conditionParamRef.containsKey('lawNameList')"> ${_conditionType_} a.lawName in <foreach collection="conditionParamRef.lawNameList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('lawType')"> <if test="conditionParamRef.lawType != null "> ${_conditionType_} a.lawType = #{${_conditionParam_}.lawType} </if> <if test="conditionParamRef.lawType == null"> ${_conditionType_} a.lawType is null </if> </if> <if test="conditionParamRef.containsKey('lawTypeList')"> ${_conditionType_} a.lawType in <foreach collection="conditionParamRef.lawTypeList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('lawTypeStart') and conditionParamRef.lawTypeStart != null"> ${_conditionType_} a.lawType <![CDATA[ >= ]]> #{${_conditionParam_}.lawTypeStart} </if> <if test="conditionParamRef.containsKey('lawTypeEnd') and conditionParamRef.lawTypeEnd != null"> ${_conditionType_} a.lawType <![CDATA[ <= ]]> #{${_conditionParam_}.lawTypeEnd} </if> <if test="conditionParamRef.containsKey('referenceNum')"> <if test="conditionParamRef.referenceNum != null and conditionParamRef.referenceNum != ''"> ${_conditionType_} a.referenceNum like #{${_conditionParam_}.referenceNum} </if> <if test="conditionParamRef.referenceNum == null"> ${_conditionType_} a.referenceNum is null </if> </if> <if test="conditionParamRef.containsKey('referenceNumList')"> ${_conditionType_} a.referenceNum in <foreach collection="conditionParamRef.referenceNumList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('clause')"> <if test="conditionParamRef.clause != null and conditionParamRef.clause != ''"> ${_conditionType_} a.clause like #{${_conditionParam_}.clause} </if> <if test="conditionParamRef.clause == null"> ${_conditionType_} a.clause is null </if> </if> <if test="conditionParamRef.containsKey('clauseList')"> ${_conditionType_} a.clause in <foreach collection="conditionParamRef.clauseList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('clauseContent')"> <if test="conditionParamRef.clauseContent != null and conditionParamRef.clauseContent != ''"> ${_conditionType_} a.clauseContent like #{${_conditionParam_}.clauseContent} </if> <if test="conditionParamRef.clauseContent == null"> ${_conditionType_} a.clauseContent is null </if> </if> <if test="conditionParamRef.containsKey('clauseContentList')"> ${_conditionType_} a.clauseContent in <foreach collection="conditionParamRef.clauseContentList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('sort')"> <if test="conditionParamRef.sort != null "> ${_conditionType_} a.sort = #{${_conditionParam_}.sort} </if> <if test="conditionParamRef.sort == null"> ${_conditionType_} a.sort is null </if> </if> <if test="conditionParamRef.containsKey('sortList')"> ${_conditionType_} a.sort in <foreach collection="conditionParamRef.sortList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> <if test="conditionParamRef.containsKey('sortStart') and conditionParamRef.sortStart != null"> ${_conditionType_} a.sort <![CDATA[ >= ]]> #{${_conditionParam_}.sortStart} </if> <if test="conditionParamRef.containsKey('sortEnd') and conditionParamRef.sortEnd != null"> ${_conditionType_} a.sort <![CDATA[ <= ]]> #{${_conditionParam_}.sortEnd} </if> <if test="conditionParamRef.containsKey('createTime')"> <if test="conditionParamRef.createTime != null "> ${_conditionType_} a.createTime = #{${_conditionParam_}.createTime} </if> <if test="conditionParamRef.createTime == null"> ${_conditionType_} a.createTime is null </if> </if> <if test="conditionParamRef.containsKey('createTimeStart') and conditionParamRef.createTimeStart != null and conditionParamRef.createTimeStart!=''"> ${_conditionType_} a.createTime <![CDATA[ >= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.createTimeStart},' 00:00:00'),19),'%Y-%m-%d %k:%i:%s') </if> <if test="conditionParamRef.containsKey('createTimeEnd') and conditionParamRef.createTimeEnd != null and conditionParamRef.createTimeEnd!=''"> ${_conditionType_} a.createTime <![CDATA[ <= ]]> STR_TO_DATE(left(concat(#{${_conditionParam_}.createTimeEnd},' 23:59:59'),19),'%Y-%m-%d %k:%i:%s') </if> <if test="conditionParamRef.containsKey('createUser')"> <if test="conditionParamRef.createUser != null and conditionParamRef.createUser != ''"> ${_conditionType_} a.createUser like #{${_conditionParam_}.createUser} </if> <if test="conditionParamRef.createUser == null"> ${_conditionType_} a.createUser is null </if> </if> <if test="conditionParamRef.containsKey('createUserList')"> ${_conditionType_} a.createUser in <foreach collection="conditionParamRef.createUserList" open="(" close=")" index="index" item="item" separator=","> #{item} </foreach> </if> </sql> <sql id="_orderCols_"> <if test="orderColList != null and !orderColList.isEmpty()"> order by <trim suffixOverrides="," suffix=""> <foreach collection="orderColList" open="" close="" index="index" item="item" separator=","> ${item.colName} ${item.sortKind} </foreach> </trim> </if> <if test="(orderColList == null or orderColList.isEmpty()) and orderCol != null and !orderCol.isEmpty()"> order by <trim suffixOverrides="," suffix=""> <if test="orderCol.containsKey('id')"> a.id <if test='orderCol.id != null and "DESC".equalsIgnoreCase(orderCol.id)'>DESC</if> , </if> <if test="orderCol.containsKey('matterid')"> a.matterid <if test='orderCol.matterid != null and "DESC".equalsIgnoreCase(orderCol.matterid)'>DESC</if> , </if> <if test="orderCol.containsKey('lawName')"> a.lawName <if test='orderCol.lawName != null and "DESC".equalsIgnoreCase(orderCol.lawName)'>DESC</if> , </if> <if test="orderCol.containsKey('lawType')"> a.lawType <if test='orderCol.lawType != null and "DESC".equalsIgnoreCase(orderCol.lawType)'>DESC</if> , </if> <if test="orderCol.containsKey('referenceNum')"> a.referenceNum <if test='orderCol.referenceNum != null and "DESC".equalsIgnoreCase(orderCol.referenceNum)'>DESC</if> , </if> <if test="orderCol.containsKey('clause')"> a.clause <if test='orderCol.clause != null and "DESC".equalsIgnoreCase(orderCol.clause)'>DESC</if> , </if> <if test="orderCol.containsKey('clauseContent')"> a.clauseContent <if test='orderCol.clauseContent != null and "DESC".equalsIgnoreCase(orderCol.clauseContent)'>DESC</if> , </if> <if test="orderCol.containsKey('sort')"> a.sort <if test='orderCol.sort != null and "DESC".equalsIgnoreCase(orderCol.sort)'>DESC</if> , </if> <if test="orderCol.containsKey('createTime')"> a.createTime <if test='orderCol.createTime != null and "DESC".equalsIgnoreCase(orderCol.createTime)'>DESC</if> , </if> <if test="orderCol.containsKey('createUser')"> a.createUser <if test='orderCol.createUser != null and "DESC".equalsIgnoreCase(orderCol.createUser)'>DESC</if> , </if> </trim> </if> </sql> <sql id="_group_by_"> <if test="groupList != null and !groupList.isEmpty()"> GROUP BY <trim suffixOverrides="," suffix=""> <foreach collection="groupList" open="" close="" index="index" item="item" separator=","> ${item} </foreach> </trim> </if> </sql> </mapper>