grgw_old_java/heatsupply2/build/classes/mappings/modules/oa/OaNotifyDao.xml

162 lines
3.8 KiB
XML

<?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">
<mapper namespace="com.jeeplus.modules.oa.dao.OaNotifyDao">
<sql id="oaNotifyColumns">
a.ID AS "id",
a.TYPE AS "type",
a.TITLE AS "title",
a.CONTENT AS "content",
a.FILES AS "files",
a.STATUS AS "status",
a.CREATE_BY AS "createBy.id",
a.CREATE_DATE AS "createDate",
a.UPDATE_BY AS "updateBy.id",
a.UPDATE_DATE AS "updateDate",
a.REMARKS AS "remarks",
a.DEL_FLAG AS "delFlag",
b.read_num,
b.un_read_num
</sql>
<sql id="oaNotifyJoins">
<!-- 查询已读和未读条数 -->
LEFT JOIN (
SELECT r.oa_notify_id,
sum(case when r.read_flag = '1' then 1 else 0 end) read_num,
sum(case when r.read_flag != '1' then 1 else 0 end) un_read_num
FROM oa_notify_record r GROUP BY r.oa_notify_id
) b ON b.oa_notify_id = a.id
</sql>
<select id="get" resultType="OaNotify">
SELECT
<include refid="oaNotifyColumns"/>
FROM oa_notify a
<include refid="oaNotifyJoins"/>
WHERE a.id = #{id}
</select>
<select id="findList" resultType="OaNotify">
SELECT
<include refid="oaNotifyColumns"/>
<if test="isSelf">,
r.read_flag
</if>
FROM oa_notify a
<include refid="oaNotifyJoins"/>
<!-- 我的通知 -->
<if test="isSelf">
JOIN oa_notify_record r ON r.oa_notify_id = a.id AND r.user_id = #{currentUser.id}
<if test="readFlag != null and readFlag != ''">
AND r.read_flag = #{readFlag}
</if>
</if>
WHERE a.del_flag = #{DEL_FLAG_NORMAL}
<if test="title != null and title != ''">
AND a.TITLE LIKE
<if test="dbName == 'oracle'">'%'||#{title}||'%'</if>
<if test="dbName == 'mysql'">CONCAT('%', #{title}, '%')</if>
</if>
<if test="type != null and type != ''">
AND a.TYPE = #{type}
</if>
<if test="status != null and status != ''">
AND a.STATUS = #{status}
</if>
<if test="isSelf">
AND a.STATUS = '1'
</if>
<if test="dbName == 'oracle'">
<if test="rownum != null and rownum != ''">
and rownum <![CDATA[<=]]> #{rownum}
</if>
</if>
ORDER BY a.update_date DESC
<if test="dbName == 'mysql'">
<if test="rownum != null and rownum != ''">
LIMIT ${rownum}
</if>
</if>
</select>
<select id="findAllList" resultType="OaNotify">
SELECT
<include refid="oaNotifyColumns"/>
FROM oa_notify a
<include refid="oaNotifyJoins"/>
WHERE a.del_flag = #{DEL_FLAG_NORMAL}
ORDER BY a.update_date DESC
</select>
<select id="findCount" resultType="Long">
SELECT
count(1)
FROM oa_notify a
<if test="isSelf">
JOIN oa_notify_record r ON r.oa_notify_id = a.id AND r.user_id = #{currentUser.id}
<if test="readFlag != null and readFlag != ''">
AND r.read_flag = #{readFlag}
</if>
</if>
WHERE a.del_flag = #{DEL_FLAG_NORMAL}
<if test="isSelf">
AND a.STATUS = '1'
</if>
</select>
<insert id="insert">
INSERT INTO oa_notify(
ID,
TYPE,
TITLE,
CONTENT,
FILES,
STATUS,
CREATE_BY,
CREATE_DATE,
UPDATE_BY,
UPDATE_DATE,
REMARKS,
DEL_FLAG
) VALUES (
#{id},
#{type},
#{title},
#{content},
#{files},
#{status},
#{createBy.id},
#{createDate},
#{updateBy.id},
#{updateDate},
#{remarks},
#{delFlag}
)
</insert>
<update id="update">
UPDATE oa_notify SET
TYPE = #{type},
TITLE = #{title},
CONTENT = #{content},
FILES = #{files},
STATUS = #{status},
UPDATE_BY = #{updateBy.id},
UPDATE_DATE = #{updateDate},
REMARKS = #{remarks}
WHERE id = #{id}
</update>
<update id="delete">
DELETE FROM oa_notify
WHERE id = #{id}
</update>
<update id="deleteByLogic">
UPDATE oa_notify SET
del_flag = #{DEL_FLAG_DELETE}
WHERE id = #{id}
</update>
</mapper>