使用Mongoose更新子文档

时间:2015-03-15 18:48:52

标签: javascript angularjs mongodb express mongoose

我正在建立一个带有角度,表达和猫鼬的简单民意调查应用程序。

我的数据如下:`

var mongoose = require('mongoose');

var responseSchema = new mongoose.Schema({
    responseText: String,
    votes: {
        type: Number,
        default: 0
    }
})
module.exports = mongoose.model('Responses', responseSchema);

var pollsSchema = new mongoose.Schema({
    question: String,
    responses: [responseSchema]
})

module.exports = mongoose.model('Polls', pollsSchema);`

所以,我有一个包含子文档响应模型的民意调查模型。

当有人投票时,我想增加回复的投票数。 这是我正在处理的查询,但它不对。

router.post('/api/polls/:id/vote', function (req, res, next) {

    console.log("Poll ID : " + req.params.id);
    console.log("Option ID : " + req.body._id);
    Polls.findOneAndUpdate({
        _id: req.params.id
    }, {

        $inc: {
            'responses.id(req.body.id).votes': 1
        }

    }, function (err, post) {

        if (err) return next(err);
        console.log(err);
        console.log(post);
        console.log(post.responses.id(req.body._id).votes);
    });
})

修改:已更新

基本上,我在req参数中发送轮询ID,并在响应正文中发送响应ID。我能够在console.log中获得投票价值,但我不知道如何编写查询。有人可以帮忙吗?

谢谢!

2 个答案:

答案 0 :(得分:0)

您可以使用$inc运算符。请参阅documentation

Polls.findOneAndUpdate({
        _id: req.params.id,
        responses._id: req.body._id
    }, {
        {$inc: {'responses.$.votes': 1}}
    });

答案 1 :(得分:0)

找到解决方案:基本上只需使用findOne缩小id,然后在回调中执行查询。看起来有点奇怪,但它确实有效。如果其他人有更好的方式,我很乐意听到。谢谢!

router.post('/api/polls/:id/vote', function (req, res, next) {

    Polls.findOne({
        _id: req.params.id
    }, 'responses', function (err, post) {
        post.responses.id(req.body._id).votes++;
        post.save();
    })
})