数据库要实现一个固定大小的用户消息队列要怎做?(术语似乎是叫环形队列

2021-02-05 15:24:10 +08:00
 love

比如有 10 万用户,每个用户每天要收 1000 消息到自己的队列,但只要保存最近 10000 条记录即可。

类似表:

userlog:
  id: int auto_increment
  user_id: int
  msg: varchar(100)
  time: datetime

感觉每天循环处理每个用户然后批量删除 10000 条后的记录性能不太好的样式:

DELETE FROM `userlog` 
WHERE id IN (select id  FROM `userlog`  ORDER BY id DESC LIMIT 10000, 250))

因为本身 mysql limit 语句要大偏移定位 10000 条记录后的记录就性能不好再加上还要每天给 10w 用户分别查询多次来删除。

似乎没有好的办法啊?或者有不用 mysql 数据库的办法吗?

1140 次点击
所在节点    MySQL
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/751591

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX