JAVA实现类似短信的留言对话功能(非实时)

项目中需要做一个私信留言功能,自己设计如下,功能倒是实现了,可能不尽完美,希望大家看后可以多多给点意见。

框架: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
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值