Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 清除集合中旧邮件/帖子的最佳方法?_Javascript_Mongodb_Meteor - Fatal编程技术网

Javascript 清除集合中旧邮件/帖子的最佳方法?

Javascript 清除集合中旧邮件/帖子的最佳方法?,javascript,mongodb,meteor,Javascript,Mongodb,Meteor,我知道这个网站更喜欢回答而不是讨论,但我对此很迷茫。 哪种方法足以清除存储在集合中的旧邮件?因为它们是消息,所以会有大量的消息 到目前为止,我有的是使用 if (Messages.find().count() > 100) { Messages.remove({ _id: Messages.findOne({}, { sort: { createdAt: 1 } })._id }); } 我也尝试过使用expire 有没有其他/更有效的方法可以做到这一点?

我知道这个网站更喜欢回答而不是讨论,但我对此很迷茫。 哪种方法足以清除存储在集合中的旧邮件?因为它们是消息,所以会有大量的消息

到目前为止,我有的是使用

if (Messages.find().count() > 100) {
    Messages.remove({
        _id: Messages.findOne({}, { sort: { createdAt: 1 } })._id
    });
}
我也尝试过使用expire


有没有其他/更有效的方法可以做到这一点?

根据您如何定义到期年龄,有两种方法可以做到这一点

第一种方法是使用它根据时间自动修剪一些集合。例如,您可能有一个日志表来记录所有应用程序事件,并且您只想将日志保留到最后一个小时。要实现这一点,请在日志文档中添加一个日期字段。这将指示文档的年龄。MongoDB将使用此字段确定您的文档是否已过期,是否需要删除:

db.log_events.insert({
   "name": "another log entry"
   "createdAt": new Date()
})
现在将TTL索引添加到此字段的集合中。在下面的示例中,我使用了3600的
expireAfterSeconds
值,它将在每小时后消除日志:

db.log_events.createIndex({ "createdAt": 1 }, { expireAfterSeconds: 3600 })
因此,对于您的情况,您需要以秒为单位定义适当的过期时间。有关更多详细信息,请参阅上的MongoDB文档


第二种方法涉及根据日期范围查询手动删除文档。对于上述给定同一集合的示例,要删除早于一小时的文档,您需要创建一个日期,表示相对于当前时间戳的一小时前,并将该日期用作集合的remove方法中的查询:

var now = new Date(),
    hourAgo = new Date(now.getTime() - (60 * 60 * 1000));

db.log_events.remove({"createdAt": { "$lte": hourAgo }})

上述操作将删除超过一小时的日志文档。

根据您如何定义过期期限,有两种方法可以实现此目的

第一种方法是使用它根据时间自动修剪一些集合。例如,您可能有一个日志表来记录所有应用程序事件,并且您只想将日志保留到最后一个小时。要实现这一点,请在日志文档中添加一个日期字段。这将指示文档的年龄。MongoDB将使用此字段确定您的文档是否已过期,是否需要删除:

db.log_events.insert({
   "name": "another log entry"
   "createdAt": new Date()
})
现在将TTL索引添加到此字段的集合中。在下面的示例中,我使用了3600的
expireAfterSeconds
值,它将在每小时后消除日志:

db.log_events.createIndex({ "createdAt": 1 }, { expireAfterSeconds: 3600 })
因此,对于您的情况,您需要以秒为单位定义适当的过期时间。有关更多详细信息,请参阅上的MongoDB文档


第二种方法涉及根据日期范围查询手动删除文档。对于上述给定同一集合的示例,要删除早于一小时的文档,您需要创建一个日期,表示相对于当前时间戳的一小时前,并将该日期用作集合的remove方法中的查询:

var now = new Date(),
    hourAgo = new Date(now.getTime() - (60 * 60 * 1000));

db.log_events.remove({"createdAt": { "$lte": hourAgo }})
上述操作将删除超过一小时的日志文档