项目中需要做一个私信留言功能,自己设计如下,功能倒是实现了,可能不尽完美,希望大家看后可以多多给点意见。
框架:Maven+Spring+SpringMvc+Mybatis 数据库:mysql
一、数据结构
设置两个表,一个聊天消息主表CU_CHAT_MESSAGE_MAIN,一个聊天消息详情表CU_CHAT_MESSAGE_DETAIL
CREATE TABLE `CU_CHAT_MESSAGE_MAIN` (
`id` char(32) NOT NULL COMMENT 'id',
`user1` char(32) NOT NULL COMMENT '用户1id',
`user1_delete_status` char(1) DEFAULT NULL COMMENT '删除 0否 1是',
`user1_delete_time` datetime DEFAULT NULL COMMENT '删除时间',
`user2` char(32) NOT NULL COMMENT '用户2id',
`user2_delete_status` char(1) DEFAULT NULL COMMENT '删除 0否 1是',
`user2_delete_time` datetime DEFAULT NULL COMMENT '删除时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COMMENT='聊天消息主表';
CREATE TABLE `CU_CHAT_MESSAGE_DETAIL` (
`id` char(32) NOT NULL,
`main_id` char(32) NOT NULL COMMENT 'CU_CHAT_MESSAGE_MAIN表id',
`send_user` char(32) NOT NULL COMMENT '发送人id',
`receive_user` char(32) NOT NULL COMMENT '接收人id',
`content_type` char(1) CHARACTER SET utf8 DEFAULT NULL COMMENT '消息类型 0 文字 1图片',
`content` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '消息内容',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`has_read` char(1) CHARACTER SET utf8 DEFAULT NULL COMMENT '已读 0否 1是',
`read_time` datetime DEFAULT NULL COMMENT '读取时间',
`withdraw_flag` char(1) DEFAULT NULL COMMENT '撤回 0未撤回 1已撤回',
`withdraw_time` datetime DEFAULT NULL COMMENT '撤回时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COMMENT='聊天消息详情表';
二、代码
这里我只贴出了service实现类的逻辑代码方法以及sql查询
注:ResultEntity类是自己封装的一个返回类
--------------------------------------------ChatMessageServiceImpl --------------------------------
import com.qianmi.bean.ChatMessageDetail;
import com.qianmi.bean.ChatMessageMain;
import com.qianmi.common.pojo.ResultEntity;
import com.qianmi.common.utils.CommonUtils;
import com.qianmi.custom.ChatMessageDetailInfo;
import com.qianmi.custom.ChatMessageMainInfo;
import com.qianmi.dao.ChatMessageDetailMapper;
import com.qianmi.dao.ChatMessageMainM