导航

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

用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的话,这个选项推荐不填。




侧边栏
最新评论
广树
2024-05-09
@夸克网盘资源:好像是这么回事,中文圈,想通过博客有收益基本是不可能的
夸克网盘资源
2024-05-09
@广树:好像中文站的广告收益也不太行
广树
2024-05-09
@夸克网盘资源:不用特意去点击,没啥收益就是个装饰品,哈哈哈
夸克网盘资源
2024-05-09
点了以下广告,有收益吗?哈哈😄
广树
2024-05-08
@Asuna:谢谢!谢谢!
正在攻略

圣兽之王.jpg

传颂之物

PSN奖杯卡

PSN奖杯卡

赞助商广告