我正在建立一个带有角度,表达和猫鼬的简单民意调查应用程序。
我的数据如下:`
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中获得投票价值,但我不知道如何编写查询。有人可以帮忙吗?
谢谢!
答案 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();
})
})