数据库要实现一个固定大小的用户消息队列要怎做?(术语似乎是叫环形队列
資深大佬 : love 2
比如有 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 数据库的办法吗?
大佬有話說 (0)