[记录,求更好方案]大量用户消息已读未读存储方式

做一个消息提示,问题如下:如果系统给所有用户推送了一条站内消息,如何区分用户是否已读,从而实现取消红点或具体未读消息数量,总不可能所有消息全部放在一个表吧,那如果有1万个用户,同样的消息要发1万条,如果是数据库的话,长久下来,负担太大了。

1、内外总条数的提醒记录


      使用redis的hash实现:
      hash的名称unread_msg_count
      hash的键user_id
      hash的值未读数
      如果有新消息可以使用hincrby(unread_msg_count,user_id,1)来处理
      用户已读时,hincrby(unread_msg_count,user_id,-1)来减1或者hdel(unread_msg_count,user_id)

2、每条记录的读取状态

    redis hash中设 unread_msg_detail,键为user_id,值为未读消息拼接, 已读时找到对应记录剔除掉。

 

 

两种我觉得在存入过程中可能会耗费较多时间,不知道还有没更好的数据结构     

如有更好方案请指正

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郭_栋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值