删除集合中旧邮件/帖子的最佳方式
Best way to get rid of old messages/posts in a collection?
我知道这个网站更喜欢答案而不是讨论,但我对此很困惑。什么是足够的方法来清除存储在集合中的旧消息?由于它们是信息,所以会有大量的信息。
到目前为止,我要么使用删除消息
if (Messages.find().count() > 100) {
Messages.remove({
_id: Messages.findOne({}, { sort: { createdAt: 1 } })._id
});
}
我也尝试过使用expire。
有其他更有效的方法吗?
根据您如何定义到期年龄,有两种方法可以实现这一点。
第一种方法是使用"TTL索引",根据时间自动修剪一些集合。例如,您可能有一个日志表来记录所有应用程序事件,并且您只想保留最后一个小时的日志。要实现此功能,请在日志文档中添加一个日期字段。这将指示文档的使用年限。MongoDB将使用此字段来确定您的文档是否已过期并需要删除:
db.log_events.insert({
"name": "another log entry"
"createdAt": new Date()
})
现在在这个字段上为您的集合添加一个TTL索引。在下面的例子中,我使用了expireAfterSeconds
值3600,它将在每小时后消除日志:
db.log_events.createIndex({ "createdAt": 1 }, { expireAfterSeconds: 3600 })
因此,对于您的情况,您需要定义一个以秒为单位的适当到期时间。有关更多详细信息,请参阅MongoDB关于使用TTL索引的数据过期的文档。
第二种方法涉及基于日期范围查询手动删除文档。对于上面给定的相同集合的示例,要删除早于一小时的文档,您需要创建一个日期,该日期表示相对于当前时间戳的一小时前,并在集合的删除方法中使用该日期作为查询:
var now = new Date(),
hourAgo = new Date(now.getTime() - (60 * 60 * 1000));
db.log_events.remove({"createdAt": { "$lte": hourAgo }})
以上操作将删除超过一小时的日志文档。
相关文章:
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式