导航

萌即是正义!时不时分享一些ACG活动记录与有趣代码的小站!

侧边栏
最新评论
广树管理员
2025-02-07 19:30
@Xia:这个暂时没有写成配置项,有这个需求吗?
Xia
2025-02-07 18:56
广树大大,我有个小问题,维基萌博客系统,邮件的发件人和标题该如何设置? ∠( ᐛ 」∠)_
火喵酱
2025-02-07 18:54
@广树:开心开心!!
广树管理员
2025-02-07 18:46
@火喵酱:尽量满足大佬的需求
火喵酱
2025-02-07 18:40
期待支持armv7,现在只有amd64没法用qaq
正在攻略

logo_kai.jpg


PSN奖杯卡

PSN奖杯卡

赞助商广告

用Mongoose限制存入MongoDB的文档数(capped)

作者:广树时间:2019-03-25 09:31:03分类:Node.js

在上篇《试着用Node.js重写了抽卡系统》中出现的查看最新动态里,原先在Emlog版里我是用json文件储存并且限制了条数,但是在Node.js版里我将动态数据储存到了MongoDB数据库当中了,于是就出现一个问题。

因为是日志类数据,以后必定会有大量不必要的数据产生,这里就需要对数据量做一个限制,超过限制就要覆盖掉最旧的数据。

这里就要用到capped。

然后查阅官方文档会发现:

new Schema({..}, { capped: 1024 });

new Schema({..}, { capped: { size: 1024, max: 1000, autoIndexId: true } });

两种写法。

这里size为必填,为一个文档的总大小,单位为字节,文档超过这个大小后就会开始覆盖旧数据。

max为文档数量,选填,如果文档超过设定值就会覆盖旧数据,但是如果在超过数量之前先超过了文档的设定大小则也会覆盖旧数据。

autoIndexId为自动创建索引也就是_id,这个设置在我5.4.19版本的Mongoose里会被提示即将废弃。所以如果是用新版的Mongoose的话,这个选项推荐不填。




donate.png

1210 x 50(蓝底).png

cloudcone