MongoDB TTL稀疏索引?

时间:2016-12-02 17:11:58

标签: mongodb indexing sparse-matrix ttl

你可以TTL稀疏的字段吗?如果是这样,你应该声明TTL索引稀疏吗?像这样?

db.eventlog.createIndex( { "lastModifiedDate": 1 }, { expireAfterSeconds: 3600 , sparse:"true"} )

1 个答案:

答案 0 :(得分:1)

> use foo
switched to db foo
> db.foo.createIndex({date: 1}, {expireAfterSeconds: 5, sparse: true})
{
    "createdCollectionAutomatically" : false,
    "numIndexesBefore" : 1,
    "numIndexesAfter" : 2,
    "ok" : 1
}

> db.foo.getIndexes()
[
    {
        "v" : 1,
        "key" : {
            "_id" : 1
        },
        "name" : "_id_",
        "ns" : "foo.foo"
    },
    {
        "v" : 1,
        "key" : {
            "date" : 1
        },
        "name" : "date_1",
        "ns" : "foo.foo",
        "expireAfterSeconds" : 5,
        "sparse" : true
    }
]

> db.foo.insert({date: new Date()})

> db.foo.find()
{ "_id" : ObjectId("5841aeb650b5412e92ebbb9b"), "date" : ISODate("2016-12-02T17:26:14.617Z") }

> db.foo.find()
>

看来这很好用。请注意,根据documentation,TTL操作每60秒左右触发一次,因此expireAfterSeconds:5可能需要更长的时间。