在一些站点会出现若干秒之后信息被删除的情况,例如:手机验证码。那么在MongoDB里面就可以轻松实现过期索引,但是这个时间往往不怎么准确。
范例:设置过期索引,10秒后过期
> db.phones.createIndex({"time":1},{expireAfterSeconds:10})
{
"createdCollectionAutomatically" : true,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
再插入数据:
db.phones.insert({"tel":110,"code":110,"time":new Date()});
db.phones.insert({"tel":111,"code":111,"time":new Date()});
db.phones.insert({"tel":112,"code":112,"time":new Date()});
db.phones.insert({"tel":113,"code":113,"time":new Date()});
db.phones.insert({"tel":114,"code":114,"time":new Date()});
查看:
> db.phones.find();
{ "_id" : ObjectId("5992b97f0184ff511bf02bb2"), "tel" : 110, "code" : 110, "time" : ISODate("2017-08-15T09:06:07.042Z") }
{ "_id" : ObjectId("5992b97f0184ff511bf02bb3"), "tel" : 111, "code" : 111, "time" : ISODate("2017-08-15T09:06:07.046Z") }
{ "_id" : ObjectId("5992b97f0184ff511bf02bb4"), "tel" : 112, "code" : 112, "time" : ISODate("2017-08-15T09:06:07.084Z") }
{ "_id" : ObjectId("5992b97f0184ff511bf02bb5"), "tel" : 113, "code" : 113, "time" : ISODate("2017-08-15T09:06:07.133Z") }
{ "_id" : ObjectId("5992b9800184ff511bf02bb6"), "tel" : 114, "code" : 114, "time" : ISODate("2017-08-15T09:06:08.142Z") }
>
等到10秒以后(永远不会那么准确)锁保存的数据就会消失。这样的特性在进行一些临时数据保存的时候非常有帮助。如果没有这个特性,而使用关系型数据库是非常麻烦的。
范例:设置过期索引,10秒后过期
> db.phones.createIndex({"time":1},{expireAfterSeconds:10})
{
"createdCollectionAutomatically" : true,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
再插入数据:
db.phones.insert({"tel":110,"code":110,"time":new Date()});
db.phones.insert({"tel":111,"code":111,"time":new Date()});
db.phones.insert({"tel":112,"code":112,"time":new Date()});
db.phones.insert({"tel":113,"code":113,"time":new Date()});
db.phones.insert({"tel":114,"code":114,"time":new Date()});
查看:
> db.phones.find();
{ "_id" : ObjectId("5992b97f0184ff511bf02bb2"), "tel" : 110, "code" : 110, "time" : ISODate("2017-08-15T09:06:07.042Z") }
{ "_id" : ObjectId("5992b97f0184ff511bf02bb3"), "tel" : 111, "code" : 111, "time" : ISODate("2017-08-15T09:06:07.046Z") }
{ "_id" : ObjectId("5992b97f0184ff511bf02bb4"), "tel" : 112, "code" : 112, "time" : ISODate("2017-08-15T09:06:07.084Z") }
{ "_id" : ObjectId("5992b97f0184ff511bf02bb5"), "tel" : 113, "code" : 113, "time" : ISODate("2017-08-15T09:06:07.133Z") }
{ "_id" : ObjectId("5992b9800184ff511bf02bb6"), "tel" : 114, "code" : 114, "time" : ISODate("2017-08-15T09:06:08.142Z") }
>
等到10秒以后(永远不会那么准确)锁保存的数据就会消失。这样的特性在进行一些临时数据保存的时候非常有帮助。如果没有这个特性,而使用关系型数据库是非常麻烦的。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/28536251/viewspace-2144103/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/28536251/viewspace-2144103/