首页 / PHP / PHP系统公告-发送通知给每个人
PHP系统公告-发送通知给每个人
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了PHP系统公告-发送通知给每个人,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4892字,纯文字阅读大概需要7分钟。
内容图文
![PHP系统公告-发送通知给每个人](/upload/InfoBanner/zyjiaocheng/201/0e593fb40c7a46c89e6e73bf21f659f7.jpg)
回复讨论(解决方案)
首先得有一个消息列表,表里面有个是否阅读字段就行了啊
首先得有一个消息列表,表里面有个是否阅读字段就行了啊
那要是有十万个用户,有的看过了有的没看过 ,这个字段怎么标注啊?这条消息是谁发的,发给谁 表里面也都需要记录啊,这样你就可以根据每个用户的用户id去读取个人的消息了
表结构
table1:message
msg_id msg_content publish_time
table2:read
msg_id user_id read_time
发布一条系统消息 在message插入一条记录即可
如:
123 “下午休息” 1414468731
看过的人在read表中插入一条记录
123 5145 1414468745
判断是否有未读信息
select * from message where msg_id not in (select msg_id from read where user_id = 5145)
如果你对sql效率关注 可以用下面的
select * from message where message left join (select* from read where user_id = 5145 )temp on message.msg_id = temp .msg_id where temp.user_id is null;
表结构
table1:message
msg_id msg_content publish_time
table2:read
msg_id user_id read_time
发布一条系统消息 在message插入一条记录即可
如:
123 “下午休息” 1414468731
看过的人在read表中插入一条记录
123 5145 1414468745
判断是否有未读信息
select * from message where msg_id not in (select msg_id from read where user_id = 5145)
如果你对sql效率关注 可以用下面的
select * from message where message left join (select* from read where user_id = 5145 )temp on message.msg_id = temp .msg_id where temp.user_id is null;
这条消息是谁发的,发给谁 表里面也都需要记录啊,这样你就可以根据每个用户的用户id去读取个人的消息了
这是针对所有人的,所以这种推送模式不太合适
表结构
table1:message
msg_id msg_content publish_time
table2:read
msg_id user_id read_time
发布一条系统消息 在message插入一条记录即可
如:
123 “下午休息” 1414468731
看过的人在read表中插入一条记录
123 5145 1414468745
判断是否有未读信息
select * from message where msg_id not in (select msg_id from read where user_id = 5145)
如果你对sql效率关注 可以用下面的
select * from message where message left join (select* from read where user_id = 5145 )temp on message.msg_id = temp .msg_id where temp.user_id is null;
哈哈 那考虑考虑 redis
10W 用用户 需要15K内存标记用户是否发送 每条消息都是15K
1.读取消息 setbit msg_123 5415 1
2.判断是否读取 getbit msg_123 5415
消息表有内容和userid,如果userid=0,表示该消息为全局
用户表中,可以增加一个字段记录查看过的消息id,用逗号隔开,比如 1,20,123
看过一条就加一个消息id
如果消息比较频繁,可以考虑单独维护一个消息查看记录表,只有uid msgid两个字段,记录已查看
弄个表把看过的人装起来???
没有查询到的就显示给他
表结构
table1:message
msg_id msg_content publish_time
table2:read
msg_id user_id read_time
发布一条系统消息 在message插入一条记录即可
如:
123 “下午休息” 1414468731
看过的人在read表中插入一条记录
123 5145 1414468745
判断是否有未读信息
select * from message where msg_id not in (select msg_id from read where user_id = 5145)
如果你对sql效率关注 可以用下面的
select * from message where message left join (select* from read where user_id = 5145 )temp on message.msg_id = temp .msg_id where temp.user_id is null;
哈哈 那考虑考虑 redis
10W 用用户 需要15K内存标记用户是否发送 每条消息都是15K
1.读取消息 setbit msg_123 5415 1
2.判断是否读取 getbit msg_123 5415
再次谢谢你的帮助!
消息表有内容和userid,如果userid=0,表示该消息为全局
用户表中,可以增加一个字段记录查看过的消息id,用逗号隔开,比如 1,20,123
看过一条就加一个消息id
如果消息比较频繁,可以考虑单独维护一个消息查看记录表,只有uid msgid两个字段,记录已查看
没有查询到的就显示给他
恩!可以这样子试试
内容总结
以上是互联网集市为您收集整理的PHP系统公告-发送通知给每个人全部内容,希望文章能够帮你解决PHP系统公告-发送通知给每个人所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。