表结构
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;

解决方案 »

  1.   


    哈哈    那考虑考虑 redis10W 用用户 需要15K内存标记用户是否发送  每条消息都是15K 1.读取消息    setbit   msg_123 5415 12.判断是否读取   getbit   msg_123 5415
      

  2.   

    消息表有内容和userid,如果userid=0,表示该消息为全局
    用户表中,可以增加一个字段记录查看过的消息id,用逗号隔开,比如 1,20,123
    看过一条就加一个消息id
    如果消息比较频繁,可以考虑单独维护一个消息查看记录表,只有uid msgid两个字段,记录已查看
      

  3.   


    哈哈    那考虑考虑 redis10W 用用户 需要15K内存标记用户是否发送  每条消息都是15K 1.读取消息    setbit   msg_123 5415 12.判断是否读取   getbit   msg_123 5415再次谢谢你的帮助!