首页 后端开发 php教程 私信消息基本功能数据库设计

私信消息基本功能数据库设计

Dec 21, 2017 pm 01:33 PM
数据库 消息 私信

本文通过数据库层面来解析私信消息基本功能的实现。

项目需求:私信功能,实现像对方发送私信消息后,在我的私信列表页面显示与发送或者接受消息的人列表,列表每条记录只显示与该对话的最新的一条消息。 点击列表中的任意一条,进入到消息对话详情页面,按照倒序显示该对话的详细内容。同时在这两个页面都可以进行删除对话,私信列表页面删除是与对方的所有会话,私信详情页面删除的是某一条对话,而且单方删除对话记录,不影响对方查看。

软件环境: mysql

说了这么多,其实总结起来就那么几个重要的点,一是私信列表每条记录只显示最后一条记录,二是单方删除对话记录,不影响对方查看。先上数据表,然后在逐一解释下。

CREATE TABLE `private_message` (
  `id` bigint(20) NOT NULL auto_increment COMMENT '主键Id',
  `user_id` bigint(20) NOT NULL COMMENT '发送者Id',
  `friend_id` bigint(20) NOT NULL COMMENT '接受者Id',  
  `sender_id` bigint(20) NOT NULL COMMENT '发送者id',  
  `receiver_id` bigint(20) NOT NULL COMMENT '接受者Id',  
  `message_type` tinyint(4) NOT NULL COMMENT '消息类型,1:普通消息 2:系统消息',  
  `message_content` varchar(500) NOT NULL COMMENT '消息内容',  
  `send_time` datetime NOT NULL COMMENT '消息发送时间',  
  `status` tinyint(4) NOT NULL default '1' COMMENT '消息状态 1:未读 2:已读 3:删除',  PRIMARY KEY  (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;123456789101112
登录后复制

建立private_message表,字段说明:

id:主键,自增长 
user_id: 发送者id,非真实发送者id 
friend_id: 接受者id,非真实接受者id 
sender_id:发送者id,真实的发送者id 
receiver_id:接受者id,真实的接受者id 
message_type:消息类型,1:普通消息 2:系统消息,区分消息列表,可以发送不同类型的消息内容 
message_content:消息内容 
send_time:消息发送时间 
status:消息状态 1:未读 2:已读 3:删除,标记不同消息状态,可以实现统计未读消息数,逻辑删除用户恢复等
登录后复制

看到这里大家该郁闷了,怎么弄两个发送者id,接受者id呢?

这里因为考虑到单方删除记录,不影响对方查看的功能,所以这里面我们需要在发送私信时,插入两份一样content内容的数据,但是在user_id,friend_id上面做点手脚了,在两次插入数据时,第二次插入的数据跟第一次插入的数据的user_id和friend_id对调。也就是:

INSERT INTO `private_message` VALUES ('1', '121', '127', '121', '127', '1', 'hello word', '2015-09-09 10:25:43', '2');INSERT INTO `private_message` VALUES ('2', '127', '121', '121', '127', '1', 'hello word', '2015-09-09 10:26:41', '1');INSERT INTO `private_message` VALUES ('3', '127', '121', '127', '121', '1', '你是程序猿吗?', '2015-09-11 10:30:16', '2');INSERT INTO `private_message` VALUES ('4', '121', '127', '127', '121', '1', '你是程序猿吗?', '2015-09-11 10:30:59', '2');1234
登录后复制

这么一来,就可以满足我们的需求了。第一条和第四条记录是给121用户看,第二条和第三条记录是给127看的,121删除的时候删除第一条或者第四条记录,当然不会影响127看第二条和第三条记录啦!!!

好了,现在可以搞定其他的功能需求了。
1、我的私信列表

SELECT p.id, COUNT(p.id) AS message_count,p.user_id,p.friend_id,p.sender_id,p.receiver_id,p.send_time,p.message_content, u.`name` AS receiver_name,u.img_url AS receiver_image FROM (SELECT * FROM private_message ORDER BY id DESC) p INNER JOIN user u on u.id=friend_id WHERE p.user_id=121 and p.`status` !=3 GROUP BY p.friend_id ORDER BY p.id DESC limit 0,101
登录后复制

2、我的私信列表详情

SELECT p.id,p.message_content,p.sender_id,p.receiver_id,p.send_time,u.`name` AS sender_name,u.img_url AS sender_image,uu.`name` AS receiver_name FROM private_message p INNER JOIN user u on u.id=p.sender_id INNER JOIN user uu on uu.id=p.friend_id WHERE p.user_id=121 and p.friend_id=127 and p.`status` !=3 ORDER BY p.id DESC limit 0,101
登录后复制

3、我的私信列表页面删除整个会话

UPDATE private_message SETstatus=3 WHERE user_id=121 AND friend_id=1271
登录后复制

4、我的私信列表详情删除单个对话

UPDATE private_message SET status=3 WHERE id=11
登录后复制

5、获取用户未读消息数量

SELECT COUNT(*) FROM private_message WHERE user_id=121 AND receiver_id=127 AND status=11
登录后复制

当然,还可以更新未读消息为已读,将已删除的用户从回收站中恢复过来,发送系统消息等等都可以实现的啦。这是,肯定有同学会说了,这个表设计的数据冗余,每条记录插入两遍,content内容多的话或者发送系统消息时,表数据太大,当然这个只是针对小型的私信功能,肯定跟大型专注于社交类网站不一样了,但是我们也可以将content内容拆分出去,新建一个content表,这里关联下id就可以减少数据冗余了。还有就是这个设计不涉及到高并发访问啦!涉及到高并发这个那就得更复杂的设计和方法途径解决啦!


相关阅读:

php 聊天一对一聊天功能源代码

如何使数据库索引的使用效率更高?

设计数据库的一般步骤及例子

以上就是本文的全部内容,如果有疑问,欢迎在评论区留言!

以上是私信消息基本功能数据库设计的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

抖音聊天记录怎么彻底消除干净 抖音聊天记录怎么彻底消除干净 May 07, 2024 am 11:14 AM

1、打开抖音app,点击界面底部的【消息】,点击需要删除的聊天对话入口。2、长按任意一条聊天记录,点击【多选】,勾选想要删除的聊天记录。3、点击右下角的【删除】按钮,在弹出的窗口中选择【确认删除】即可将这些记录永久删除。

抖音私信聊天记录删了怎么恢复 抖音私信聊天记录删了怎么恢复 May 06, 2024 pm 01:47 PM

1、当用户删除了抖音私信聊天记录后,通常情况下这些记录是无法恢复的,因为这是一种永久性删除。2、但是,用户可以通过联系抖音官方,尝试沟通以恢复聊天记录。3、打开抖音app,在【我】的界面点击右上角的三条横杠,选择【设置】,向下滑动至底部,点击【关于抖音】。4、找到并拨打【客户服务热线】,或通过官方邮箱与抖音官方取得联系,了解恢复聊天记录的可能性。

Go语言如何实现数据库的增删改查操作? Go语言如何实现数据库的增删改查操作? Mar 27, 2024 pm 09:39 PM

Go语言是一种高效、简洁且易于学习的编程语言,因其在并发编程和网络编程方面的优势而备受开发者青睐。在实际开发中,数据库操作是不可或缺的一部分,本文将介绍如何使用Go语言实现数据库的增删改查操作。在Go语言中,我们通常使用第三方库来操作数据库,比如常用的sql包、gorm等。这里以sql包为例介绍如何实现数据库的增删改查操作。假设我们使用的是MySQL数据库。

Hibernate 如何实现多态映射? Hibernate 如何实现多态映射? Apr 17, 2024 pm 12:09 PM

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

怎么关闭快手的私信提醒?私信怎样关闭弹出消息? 怎么关闭快手的私信提醒?私信怎样关闭弹出消息? Mar 27, 2024 pm 09:21 PM

快手作为一个短视频平台,让用户可以随时随地分享自己的生活。频繁的私信提醒可能会打扰到我们的日常生活。那么,怎么关闭快手的私信提醒呢?一、怎么关闭快手的私信提醒?要关闭快手的私信提醒,需要进入快手的设置菜单。在快手首页,点击右下角的“我的”按钮,找到“设置”选项并点击进入。进入设置菜单后,浏览找到“通知设置”或“消息设置”选项,点击进入后,会看到“私信提醒”的选项。点击进入私信提醒,然后将开关关闭,这样就可以停止收到私信提醒。二、快手私信怎样关闭弹出消息?除了关闭私信提醒外,如果你还希望能够关闭私

抖音私信铃声在哪里设置?它来了私信没有声音提醒怎么解决? 抖音私信铃声在哪里设置?它来了私信没有声音提醒怎么解决? Apr 01, 2024 am 11:51 AM

抖音作为全球最受欢迎的短视频平台之一,拥有庞大的用户群体和丰富的功能。私信功能是用户之间互动的重要方式,而私信铃声则是提醒用户收到新私信的重要方式。那么,抖音私信铃声在哪里设置呢?本文将详细介绍如何设置抖音私信铃声,以及如何解决来了私信没有声音提醒的问题。一、抖音私信铃声在哪里设置?1.打开抖音应用:首先,打开你的抖音应用。2.进入私信界面:在抖音首页下方,点击“消息”图标,进入私信界面。3.打开设置:在私信界面的右上角,点击设置图标(通常是齿轮形状)。4.选择私信设置:在设置菜单中,找到并选择

深入解析HTML如何读取数据库 深入解析HTML如何读取数据库 Apr 09, 2024 pm 12:36 PM

HTML无法直接读取数据库,但可以通过JavaScript和AJAX实现。其步骤包括建立数据库连接、发送查询、处理响应和更新页面。本文提供了利用JavaScript、AJAX和PHP来从MySQL数据库读取数据的实战示例,展示了如何在HTML页面中动态显示查询结果。该示例使用XMLHttpRequest建立数据库连接,发送查询并处理响应,从而将数据填充到页面元素中,实现了HTML读取数据库的功能。

See all articles