如何在Mongoose中创建文档的TTL日期?

时间:2014-06-18 00:00:48

标签: javascript node.js mongodb mongoose

我正在尝试在Mongoose中创建一个promoCode架构。在创建时,我需要能够设置促销代码的到期日期。促销代码不一定具有相同的TTL。我看了this question,但我的文件还没有到期。

这是我的promoCode.js文件:

var mongoose = require("mongoose");
var promoCodeSchema = mongoose.Schema({
    expirationDate: Date,
    createdAt: {
        type: Date,
        expireAfterSeconds: Number,
        default: Date.now
    }
})
module.exports = mongoose.model("Promo", promoCodeSchema);

现在,在routes.js,我有:

app.post("/admin/promo/create", isLoggedIn, isVerified, isAdmin, function (req, res) {
    var promo = new Promo();
    promo.createdAt.expireAfterSeconds = 60;
    // for reference, note the actual day on which the promo code should expire
    var days = parseInt(req.body.expiration.replace(/[^\d]+/g, "")) || 1;
    promo.expirationDate = new Date(Date.now() + (days * 24 * 3600 * 1000));

    promo.save(function (err) {
        console.log(err, promo);
        return res.redirect("/admin/promo");
    });
})

这不起作用。我还需要能够获得TTL的值。我该如何解决这个问题?

1 个答案:

答案 0 :(得分:3)

如果要为每个文档使用不同的TTL值,可以在包含到期时间戳的字段上使用expires时间0(如所述here所述),然后将该时间戳设置为反映每个文档的所需TTL。

您已经在模式中计算expirationDate,因此您希望将TTL索引放在该字段而不是createdDate上。但是您需要在定义中使用expires,而不是像您使用的expiresAtSeconds

var promoCodeSchema = mongoose.Schema({
    expirationDate: {
        type: Date,
        expires: 0
    },
    createdAt: {
        type: Date,
        default: Date.now
    }
});

然后在routes.js中,您只需要将新expirationDate文档上的Promo设置为其到期时间戳(就像您已经在做的那样)。