<?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:2022-11-24 10:34:34
|
* @version 1.0.0
|
-->
|
<mapper namespace="cn.huge.module.notice.dao.mapper.NoticeJoinMapper">
|
<!-- 结果集 -->
|
<resultMap id="dataResult" type="cn.huge.module.notice.domain.po.NoticeJoin">
|
<result property="id" column="id"/>
|
<result property="taskId" column="task_id"/>
|
<result property="caseId" column="case_id"/>
|
<result property="title" column="title"/>
|
<result property="taskName" column="task_name"/>
|
<result property="taskTime" column="task_time"/>
|
<result property="expireTime" column="expire_time"/>
|
<result property="userId" column="user_id"/>
|
<result property="userName" column="user_name"/>
|
<result property="visitUrl" column="visit_url"/>
|
<result property="readStatus" column="read_status"/>
|
<result property="readTime" column="read_time"/>
|
<result property="deleteStatus" column="delete_status"/>
|
<result property="custId" column="cust_id"/>
|
<result property="createTime" column="create_time"/>
|
<result property="updateTime" column="update_time"/>
|
</resultMap>
|
<!-- 表 -->
|
<sql id='table-name'>dyh_notice_join</sql>
|
<!-- 字段 -->
|
<sql id="column-part">
|
id,
|
task_id,
|
case_id,
|
title,
|
task_name,
|
task_time,
|
expire_time,
|
user_id,
|
user_name,
|
visit_url,
|
read_status,
|
read_time,
|
delete_status,
|
cust_id,
|
create_time,
|
update_time
|
</sql>
|
<!-- 更新实体字段 -->
|
<sql id="set-part">
|
<if test="entity.taskId != null">task_id = #{entity.taskId},</if>
|
<if test="entity.caseId != null">case_id = #{entity.caseId},</if>
|
<if test="entity.title != null">title = #{entity.title},</if>
|
<if test="entity.taskName != null">task_name = #{entity.taskName},</if>
|
<if test="entity.taskTime != null">task_time = #{entity.taskTime},</if>
|
<if test="entity.expireTime != null">expire_time = #{entity.expireTime},</if>
|
<if test="entity.userId != null">user_id = #{entity.userId},</if>
|
<if test="entity.userName != null">user_name = #{entity.userName},</if>
|
<if test="entity.visitUrl != null">visit_url = #{entity.visitUrl},</if>
|
<if test="entity.readStatus != null">read_status = #{entity.readStatus},</if>
|
<if test="entity.readTime != null">read_time = #{entity.readTime},</if>
|
<if test="entity.deleteStatus != null">delete_status = #{entity.deleteStatus},</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.taskId != null and terms.taskId !=''">
|
and task_id = #{terms.taskId}
|
</if>
|
<if test="terms.caseId != null and terms.caseId !=''">
|
and case_id = #{terms.caseId}
|
</if>
|
<if test="terms.title != null and terms.title !=''">
|
and title = #{terms.title}
|
</if>
|
<if test="terms.taskName != null and terms.taskName !=''">
|
and task_name = #{terms.taskName}
|
</if>
|
<if test="terms.taskTime != null and terms.taskTime !=''">
|
and task_time = #{terms.taskTime}
|
</if>
|
<if test="terms.expireTime != null and terms.expireTime !=''">
|
and expire_time = #{terms.expireTime}
|
</if>
|
<if test="terms.userId != null and terms.userId !=''">
|
and user_id = #{terms.userId}
|
</if>
|
<if test="terms.userName != null and terms.userName !=''">
|
and user_name = #{terms.userName}
|
</if>
|
<if test="terms.visitUrl != null and terms.visitUrl !=''">
|
and visit_url = #{terms.visitUrl}
|
</if>
|
<if test="terms.readStatus != null and terms.readStatus !=''">
|
and read_status = #{terms.readStatus}
|
</if>
|
<if test="terms.readTime != null and terms.readTime !=''">
|
and read_time = #{terms.readTime}
|
</if>
|
<if test="terms.deleteStatus = null and terms.deleteStatus =''">
|
and delete_status = '1'
|
</if>
|
<if test="terms.deleteStatus != null and terms.deleteStatus !=''">
|
and delete_status = #{terms.deleteStatus}
|
</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="updateNoticeJoin">
|
update
|
<include refid="table-name"/>
|
<set>
|
<include refid="set-part"/>
|
</set>
|
<where>
|
id = #{entity.id}
|
</where>
|
</update>
|
<!-- 条件更新对象 -->
|
<update id="updateNoticeJoinTerms">
|
update
|
<include refid="table-name"/>
|
<set>
|
<include refid="set-part"/>
|
</set>
|
<include refid="where-part"/>
|
</update>
|
<!-- 根据编号物理删除 -->
|
<delete id="deleteNoticeJoin">
|
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>
|
|
</mapper>
|