<?xml version="1.0" encoding="UTF-8" ?>
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!--
|
* @title: 调度指标表(按纠纷类型调度)
|
* @description: 自定义sql,请自行实现业务逻辑
|
* @company: hugeinfo
|
* @author: liyj
|
* @time:2024-09-03 21:27:05
|
* @version 1.0.0
|
-->
|
<mapper namespace="cn.huge.module.casedisp.dao.mapper.DispNormCauseMapper">
|
<!-- 结果集 -->
|
<resultMap id="dataResult" type="cn.huge.module.casedisp.domain.po.DispNormCause">
|
<result property="id" column="id"/>
|
<result property="caseType" column="case_type"/>
|
<result property="caseTypeName" column="case_type_name"/>
|
<result property="targetUnitLevel" column="target_unit_level"/>
|
<result property="targetUnitId" column="target_unit_id"/>
|
<result property="targetUnitName" column="target_unit_name"/>
|
<result property="priority" column="priority"/>
|
<result property="userId" column="user_id"/>
|
<result property="custId" column="cust_id"/>
|
<result property="createTime" column="create_time"/>
|
<result property="updateTime" column="update_time"/>
|
</resultMap>
|
<!-- 表 -->
|
<sql id='table-name'>dyh_disp_norm_cause</sql>
|
<!-- 字段 -->
|
<sql id="column-part">
|
id,
|
case_type,
|
case_type_name,
|
target_unit_level,
|
target_unit_id,
|
target_unit_name,
|
priority,
|
user_id,
|
cust_id,
|
create_time,
|
update_time
|
</sql>
|
<!-- 更新实体字段 -->
|
<sql id="set-part">
|
<if test="entity.caseType != null">case_type = #{entity.caseType},</if>
|
<if test="entity.caseTypeName != null">case_type_name = #{entity.caseTypeName},</if>
|
<if test="entity.targetUnitLevel != null">target_unit_level = #{entity.targetUnitLevel},</if>
|
<if test="entity.targetUnitId != null">target_unit_id = #{entity.targetUnitId},</if>
|
<if test="entity.targetUnitName != null">target_unit_name = #{entity.targetUnitName},</if>
|
<if test="entity.priority != null">priority = #{entity.priority},</if>
|
<if test="entity.userId != null">user_id = #{entity.userId},</if>
|
<if test="entity.custId != null">cust_id = #{entity.custId},</if>
|
<if test="entity.createTime != null">create_time = #{entity.createTime},</if>
|
<if test="entity.updateTime != null">update_time = #{entity.updateTime}</if>
|
</sql>
|
<!-- 条件 -->
|
<sql id="where-part">
|
<if test="terms != null">
|
<where>
|
<if test="terms.id != null and terms.id !=''">
|
and id = #{terms.id}
|
</if>
|
<if test="terms.caseType != null and terms.caseType !=''">
|
and case_type = #{terms.caseType}
|
</if>
|
<if test="terms.caseTypeName != null and terms.caseTypeName !=''">
|
and case_type_name = #{terms.caseTypeName}
|
</if>
|
<if test="terms.targetUnitLevel != null and terms.targetUnitLevel !=''">
|
and target_unit_level = #{terms.targetUnitLevel}
|
</if>
|
<if test="terms.targetUnitId != null and terms.targetUnitId !=''">
|
and target_unit_id = #{terms.targetUnitId}
|
</if>
|
<if test="terms.targetUnitName != null and terms.targetUnitName !=''">
|
and target_unit_name = #{terms.targetUnitName}
|
</if>
|
<if test="terms.priority != null and terms.priority !=''">
|
and priority = #{terms.priority}
|
</if>
|
<if test="terms.userId != null and terms.userId !=''">
|
and user_id = #{terms.userId}
|
</if>
|
<if test="terms.custId != null and terms.custId !=''">
|
and cust_id = #{terms.custId}
|
</if>
|
<if test="terms.createTime != null and terms.createTime !=''">
|
and DATE_FORMAT(create_time,'%Y-%m-%d') = #{terms.createTime}
|
</if>
|
<if test="terms.createStart != null and terms.createStart !='' and terms.createEnd != null and terms.createEnd !=''">
|
and (DATE_FORMAT(create_time,'%Y-%m-%d') <![CDATA[ >= ]]> #{terms.createStart}
|
and DATE_FORMAT(create_time,'%Y-%m-%d') <![CDATA[ <= ]]> #{terms.createEnd})
|
</if>
|
<if test="terms.updateTime != null and terms.updateTime !=''">
|
and DATE_FORMAT(update_time,'%Y-%m-%d') = #{terms.updateTime}
|
</if>
|
<if test="terms.updateStart != null and terms.updateStart !='' and terms.updateEnd != null and terms.updateEnd !=''">
|
and (DATE_FORMAT(update_time,'%Y-%m-%d') <![CDATA[ >= ]]> #{terms.updateStart}
|
and DATE_FORMAT(update_time,'%Y-%m-%d') <![CDATA[ <= ]]> #{terms.updateEnd})
|
</if>
|
</where>
|
</if>
|
</sql>
|
<!-- 更新对象 -->
|
<update id="updateDispNormCause">
|
update
|
<include refid="table-name"/>
|
<set>
|
<include refid="set-part"/>
|
</set>
|
<where>
|
id = #{entity.id}
|
</where>
|
</update>
|
<!-- 条件更新对象 -->
|
<update id="updateDispNormCauseTerms">
|
update
|
<include refid="table-name"/>
|
<set>
|
<include refid="set-part"/>
|
</set>
|
<include refid="where-part"/>
|
</update>
|
<!-- 根据编号物理删除 -->
|
<delete id="deleteDispNormCause">
|
delete from
|
<include refid="table-name" />
|
where id = #{id}
|
</delete>
|
<!-- 根据条件查询 -->
|
<select id="listTerms" resultMap="dataResult">
|
select
|
<include refid="column-part"/>
|
from
|
<include refid="table-name" />
|
<include refid="where-part"/>
|
</select>
|
<!-- 根据条件统计 -->
|
<select id="countTerms" resultType="java.lang.Long">
|
select
|
COUNT(1)
|
from
|
<include refid="table-name" />
|
<include refid="where-part"/>
|
</select>
|
<!-- 根据条件分页查询 -->
|
<select id="pageTerms" resultMap="dataResult">
|
SELECT
|
<include refid="column-part"/>
|
FROM
|
<include refid="table-name" />
|
<include refid="where-part"/>
|
<if test="page.sort != null">
|
<foreach collection="page.sort" item="s" index="index" separator="," open="order by ">
|
isnull(${s.property}), ${s.property} ${s.direction}
|
</foreach>
|
</if>
|
<if test="page.sort == null">
|
order by isnull(create_time), create_time desc
|
</if>
|
limit #{page.offset}, #{page.size}
|
</select>
|
|
|
<!-- 根据条件获取对应综治中心组织 -->
|
<select id="getZzzxUnitByTerms" resultType="cn.huge.module.casedisp.domain.dto.ZzzxUnitDTO">
|
SELECT
|
id as unitId, unit_name as unitName, unit_grade as unitGrade, unit_type as unitType
|
FROM dyh_ct_unit
|
where unit_type = 101
|
<include refid="getZzzxUnitByTerms-where-part"/>
|
limit 1
|
</select>
|
<!-- 根据条件获取对应综治中心组织-条件 -->
|
<sql id="getZzzxUnitByTerms-where-part">
|
<if test="terms != null">
|
<if test="terms.road != null and terms.road !=''">
|
and road = #{terms.road}
|
</if>
|
<if test="terms.area != null and terms.area !=''">
|
and area = #{terms.area}
|
</if>
|
<if test="terms.city != null and terms.city !=''">
|
and city = #{terms.city}
|
</if>
|
</if>
|
</sql>
|
|
</mapper>
|