导航

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

侧边栏
最新评论
广树
2024-07-21 16:30
@火喵酱:看介绍这应该是旧版本的玩法吧?
火喵酱
2024-07-21 16:23
@广树:就是起飞降落,观赏一下新星球,改装一下飞船什么的,就感觉一直在重复操作
广树
2024-07-21 11:52
@Jacylunatic:是呀,这么多年了仍然坚持免费更新
Jacylunatic
2024-07-21 11:46
无人深空貌似最近更了波大的?说不定今年又能拿个最佳运营(笑)
广树
2024-07-21 10:26
@火喵酱:毕竟浩瀚的宇宙就很空洞。 不过最近有大型更新,有了许多新内容,大佬可以再体验体验?
正在攻略

あおかなEXTRA1

黑白的莫比乌斯.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的话,这个选项推荐不填。