5

我在 Mongo DB 中有以下类型的记录。

{
    "_id" : ObjectId("50217d8874ebb0e4e52cc07d"),   
    "timestamp" : "8/7/12 1:41:36 PM Pacific Daylight Time",
    "_ts" : ISODate("2012-08-07T20:41:44.119Z")
}

如何删除旧记录?我尝试过类似的东西db.offlineLogs.remove({timestamp: {$lt:new Date("2012, 8, 3")}});,但它不起作用。

4

3 回答 3

6

用这个解决了它:db.offlineLogs.remove({"_ts":{"$lt":ISODate("2012-08-01T19:30:07.805Z")}});

于 2012-08-07T21:05:22.913 回答
3

您也可以检查使用 TimeToLive

MongoDB 有一个功能TimeToLive,您可以指定希望文档在集合中存在多长时间后自动删除。

例如,假设您有一个名为 billing 的集合,其中包含以下字段:

{ 
    "_id" : ObjectId("59a05ef17055161ef66e9b21"), 
    "receiptId" : NumberInt(31124124), 
    "salesperson" : "jack", 
    "salesTime" : ISODate("2017-08-25T17:32:23.157+0000")
}

您可以在此集合上创建索引,例如:

db.billing.createIndex( { "salesTime": 1 }, { expireAfterSeconds: 3600 });

这将使集合中的任何文档在一小时(3600 秒)后根据 salesTime 字段被删除。

于 2017-08-24T23:50:04.333 回答
1

在您的原始查询中,timestamp它只是一个字符串字段,Date()在 Mongo shell 中将被视为字符串。比较这些操作数将像任何其他字符串比较一样工作:

$ mongo
MongoDB shell version: 2.2.0-rc1-pre-
connecting to: test
> db.foo.drop()
true
> db.foo.insert({ x: Date() });
> db.foo.find()
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> sleep(1000)
null
> db.foo.find({ x: { $lt: Date() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> db.foo.find({ x: { $gt: Date() }});
> 

ISODate()Mongo date fields$gt的 JS 等价物,在使用or运算符时无法与字符串值进行比较$lt

> db.foo.find({ x: { $gt: ISODate() }});
> db.foo.find({ x: { $lt: ISODate() }});
> db.foo.find({ x: { $ne: ISODate() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> db.foo.insert({x: ISODate() });
> db.foo.find({ x: {$gt: Date() }});
> db.foo.find({ x: {$lt: Date() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> db.foo.find({ x: {$ne: Date() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
{ "_id" : ObjectId("50218fa18930273947a21cf4"), "x" : ISODate("2012-08-07T21:58:57.350Z") }
>

Mongo 确实定义了 types 之间的比较顺序,其中字符串出现在日期之前,但是当同一字段在集合中可能具有不同的类型时,这与排序顺序有关。

请注意,如果您设想自己经常做某事(例如在批处理中)删除旧记录,您可能会对TTL 集合感兴趣,这是即将发布的 2.2 版本中的新功能。Kristina Chodorow 还在这篇博文中就该主题写了一篇有趣的介绍。

于 2012-08-07T22:05:41.177 回答