auth-server-java/service/src/main/resources/mapper/MessageMapper.xml

84 lines
3.5 KiB
XML
Raw Normal View History

<?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="cn.bunny.services.mapper.MessageMapper">
<!-- 通用查询映射结果 -->
<resultMap id="BaseResultMap" type="cn.bunny.dao.entity.system.Message">
<id column="id" property="id"/>
2024-10-30 16:56:30 +08:00
<id column="create_time" property="createTime"/>
<id column="update_time" property="updateTime"/>
<id column="create_user" property="createUser"/>
<id column="update_user" property="updateUser"/>
<id column="is_deleted" property="isDeleted"/>
<id column="title" property="title"/>
<id column="send_user_id" property="sendUserId"/>
<id column="message_type" property="messageType"/>
<id column="content" property="content"/>
2024-10-31 16:58:50 +08:00
<id column="cover" property="cover"/>
<id column="summary" property="summary"/>
2024-10-30 16:56:30 +08:00
<id column="editor_type" property="editorType"/>
2024-11-01 00:09:11 +08:00
<id column="level" property="level"/>
<id column="extra" property="extra"/>
</resultMap>
<!-- 通用查询结果列 -->
<sql id="Base_Column_List">
2024-11-03 18:56:38 +08:00
id, create_time, update_time, create_user, update_user, is_deleted, title, send_user_id, message_type, content, cover, summary, editor_type, level,extra
</sql>
<!-- 根据消息所有包含匹配当前消息Id的列表 -->
2024-11-03 18:56:38 +08:00
<select id="selectListByPageWithMessageUserDto" resultType="cn.bunny.dao.vo.system.message.MessageVo">
SELECT
message.id,
message.title,
message.cover,
message.summary,
message.level,
message.extra,
message.update_time,
message_received.id AS message_received_id,
message_received.status AS status,
message_type.message_type AS message_type
FROM sys_message message
LEFT JOIN sys_user create_user ON create_user.id = message.create_user
LEFT JOIN sys_user update_user ON update_user.id = message.update_user
LEFT JOIN sys_message_type message_type ON message_type.id = message.message_type
INNER JOIN sys_message_received message_received ON message_received.received_user_id = #{userId}
AND message.id = message_received.message_id
<where>
2024-11-02 17:03:38 +08:00
message.is_deleted = 0
<if test="dto.status != null">
2024-11-03 18:56:38 +08:00
and message_received.status = #{dto.status}
</if>
<if test="dto.messageType != null and dto.messageType != ''">
2024-11-03 18:56:38 +08:00
and message_type.message_type = #{dto.messageType}
2024-11-02 17:03:38 +08:00
</if>
<if test="dto.title != null and dto.title != ''">
and message.title like CONCAT('%',#{dto.title},'%')
</if>
</where>
2024-11-01 00:09:11 +08:00
</select>
<!-- 根据消息id查询消息详情 -->
<select id="selectMessageVoById" resultType="cn.bunny.dao.vo.system.message.MessageVo">
SELECT message.*,
send_user.nickname AS send_nickname
FROM sys_message message
LEFT JOIN sys_user update_user ON update_user.id = message.update_user
LEFT JOIN sys_user send_user ON send_user.id = message.send_user_id
WHERE message.id = #{id}
2024-11-02 17:03:38 +08:00
and message.is_deleted = 0
</select>
2024-11-01 00:09:11 +08:00
2024-10-30 16:56:30 +08:00
<!-- 物理删除系统消息 -->
<delete id="deleteBatchIdsWithPhysics">
delete
from sys_message
2024-11-02 17:03:38 +08:00
where is_deleted=0 and id in
2024-10-30 16:56:30 +08:00
<foreach collection="ids" item="id" open="(" close=")" separator=",">
#{id}
</foreach>
</delete>
</mapper>