PHP 站内消息的表结构设计 最佳方案

php中文网
发布: 2016-06-06 20:30:04
原创
1398人浏览过

需求:

<code>1)管理员可以群发信息,群发给单独用户或者所有用户。
2)用户收到的信息会可标记为已阅读。
</code>
登录后复制

个人思路:

立即学习PHP免费学习笔记(深入)”;

<code class="sql">1.tb_message (id,content,fromUid,toUid [0表示全站用户,>0表示发送给某个用户]) 
2.tb_message_readlog (readLogId,messageId,uid,isread)
</code>
登录后复制

1)添加全站通知:信息存入到 tb_message 2)用户点开信息或者设置信息为已阅读:插入记录到 tb_message_readlog

如何设计存储的表?求最佳方案

KesionEshop 免费正式版(UTF-8)
KesionEshop 免费正式版(UTF-8)

KesionEshop 是漳州科兴信息技术有限公司开发的一套电子商务建站平台系统,内置强大的网站内容管理系统及论坛系统,是目前最为流行的电子网站建设解决方案之一,V9.5采用ASP+ACCESS/MSSQL架构,系统具有极强的可扩展性,并且一直以来完全开放源代码;这套系统自2006年发布的第一个版来以来,以其简单易用、功能强大、拓展性极灵活而倍受广大用户的青睐,至今已累计三十万的用户群。

KesionEshop 免费正式版(UTF-8) 0
查看详情 KesionEshop 免费正式版(UTF-8)

回复内容:

需求:

<code>1)管理员可以群发信息,群发给单独用户或者所有用户。
2)用户收到的信息会可标记为已阅读。
</code>
登录后复制

个人思路:

立即学习PHP免费学习笔记(深入)”;

<code class="sql">1.tb_message (id,content,fromUid,toUid [0表示全站用户,>0表示发送给某个用户]) 
2.tb_message_readlog (readLogId,messageId,uid,isread)
</code>
登录后复制

1)添加全站通知:信息存入到 tb_message 2)用户点开信息或者设置信息为已阅读:插入记录到 tb_message_readlog

如何设计存储的表?求最佳方案

全站消息时候,isread不是不起作用了吗?个人感觉用序列化判断省事点

消息表message:
编号 id
时间 date
标题 title
正文 content
未读用户 unread
接收用户 receive
发送用户 send

字段receive保存消息接收人的ID序列如1,2,3,4(用逗号分隔).
字段unread保存未阅读消息的接收人的ID序列,unread初始值也为所有接收人,阅读过消息的用户则从中删除掉.
可以用MySQL内部函数FIND_IN_SET(返回找到的位置,从1开始)进行查询.
比如,查询编号为2的用户的未读信息:

<code>SELECT * FROM `message` WHERE FIND_IN_SET('2', `unread`);
</code>
登录后复制

或者使用全文检索(需要对字段unread建立全文索引,ID序列用空格隔开,如1 2 3 4):

<code>SELECT * FROM `message` WHERE MATCH(`unread`) AGAINST('2');
</code>
登录后复制

数据量比较大的话,FIND_IN_SET可能会存在性能问题,建议定时清理消息表过期的已经阅读过的消息.

大概思路跟你的差不多,这样就可以满足大部分的消息了

1.tb_message (id,content,fromUid,toUid [0表示全站用户,>0表示发送给某个用户]) 2.tb_message_readlog (readLogId,messageId,uid,isread)

不过如果你的消息数据量比较大,建议你分表处理,可以根据用户的id来分表,比如id=123456的用户发送的消息就放到tb_message6,类似这样的处理

<code>CREATE TABLE `message` (
    `message_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '消息id',
    `subject` varchar(250) NOT NULL DEFAULT '' COMMENT '主题',
    `content` varchar(500) NOT NULL DEFAULT '' COMMENT '内容',
    `type` tinyint(1) NOT NULL DEFAULT '0' COMMENT '消息类型 0 Message',
    `status` tinyint(1) NOT NULL DEFAULT '0' COMMENT '状态 -1删除 0默认',
    `create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',
    PRIMARY KEY(`message_id`),
    KEY `subject` (`subject`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE `message_broadcast` (
    `message_broadcast_id` bigint(20) NOT NULL AUTO_INCREMENT,
    `message_id` bigint(20) NOT NULL DEFAULT '0' COMMENT '消息id',
    `sender` bigint(20) NOT NULL DEFAULT '0' COMMENT '发送者',
    `receiver` bigint(20) NOT NULL DEFAULT '0' COMMENT '接收者',
    `is_read` tinyint(1) NOT NULL DEFAULT '0' COMMENT '状态 0未读 1已读',
    PRIMARY KEY(`message_broadcast_id`),
    KEY `message_id` (`message_id`),
    KEY `sender` (`sender`),
    KEY `receiver` (`receiver`),
    KEY `is_read` (`is_read`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='消息广播表';</code>
登录后复制

相关标签:
php
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号