已经一年多了,但这可能对其他人有用,所以这是我的答案:
我正在尝试完成同样的事情,以便在删除条目后允许宽限期,以便用户可以在之后取消操作。
正如Mike Bennett所说,您可以使用 TTL 索引使文档在特定时钟时间过期。
你必须创建一个索引,将其设置expireAfterSeconds
为零:
db.yourCollection.createIndex({ "expireAt": 1 }, { expireAfterSeconds: 0 });
这不会影响您集合中的任何文档,除非您在特定文档上设置 expireAfterSeconds ,如下所示:
db.log_events.insert( {
"expireAt": new Date('July 22, 2013 14:00:00'),
"logEvent": 2,
"logMessage": "Success!"
} )
猫鼬的例子
模型
var BeerSchema = new Schema({
name: {
type: String,
unique: true,
required: true
},
description: String,
alcohol: Number,
price: Number,
createdAt: { type: Date, default: Date.now }
expireAt: { type: Date, default: undefined } // you don't need to set this default, but I like it there for semantic clearness
});
BeerSchema.index({ "expireAt": 1 }, { expireAfterSeconds: 0 });
宽限期删除
使用时刻进行日期操作
exports.deleteBeer = function(id) {
var deferred = q.defer();
Beer.update(id, { expireAt: moment().add(10, 'seconds') }, function(err, data) {
if(err) {
deferred.reject(err);
} else {
deferred.resolve(data);
}
});
return deferred.promise;
};
恢复删除
使用时刻进行日期操作
exports.undeleteBeer = function(id) {
var deferred = q.defer();
// Set expireAt to undefined
Beer.update(id, { $unset: { expireAt: 1 }}, function(err, data) {
if(err) {
deferred.reject(err);
} else {
deferred.resolve(data);
}
});
return deferred.promise;
};