表结构
table1:message
msg_id msg_content publish_timetable2: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;
哈哈 那考虑考虑 redis10W 用用户 需要15K内存标记用户是否发送 每条消息都是15K 1.读取消息 setbit msg_123 5415 12.判断是否读取 getbit msg_123 5415
用户表中,可以增加一个字段记录查看过的消息id,用逗号隔开,比如 1,20,123
看过一条就加一个消息id
如果消息比较频繁,可以考虑单独维护一个消息查看记录表,只有uid msgid两个字段,记录已查看
哈哈 那考虑考虑 redis10W 用用户 需要15K内存标记用户是否发送 每条消息都是15K 1.读取消息 setbit msg_123 5415 12.判断是否读取 getbit msg_123 5415再次谢谢你的帮助!