Сохранить документ после обновления поддокумента mongoose, mongodb
Я хочу обновить значение вложенного документа и после этого сохранить основной документ. Таким образом, изменения в поддокументе сохраняются в базе данных. Вот мой код банкомата, я нахожу правильный поддокумент, это не проблема, я думаю. Но это не сохраняет изменения.
projectModel.findById({_id: req.body.projectId})
.then(function(doc){
question = doc.qp.questions.filter(q => {return q._id == req.body.questionId})[0];
var ans = question.answers.filter(a => {return a._id == req.body.answerId})[0];
if(ans)
{console.log(ans)}
ans.value = req.body.answerValue;
doc.save().then(res.send({questionId: req.body.questionId,answerId: req.body.answerId,answerValue: req.body.answerValue}))
})
.catch(error => console.log(error))
мой объект довольно сложный, и это должно быть.. это выглядит примерно так:
project={
prop,
prop,
prop,
qp:{
prop,
prop,
prop,
questions:[
question:{
prop,
prop,
prop,
answers:[
answerModels<--!this i want to find and edit!-->
]
}
]
}
}
2 ответа
Вы должны рассмотреть функцию FindOneAndUpdate Mongoose.
Это позволит вам найти ваш документ, отредактировать его и сохранить обратно в MongoDB.
Я решил это так:
projectModel.findById({_id: req.body.projectId},function (err, doc)
{
if(err)
{
console.log(err)
return;
}
for (i in doc.qp.questions) {
if(doc.qp.questions[i]._id == req.body.questionId)
{
for(y in doc.qp.questions[i].answers)
{
if(doc.qp.questions[i].answers[y]._id == req.body.answerId)
{
var test = doc.qp.questions[i].answers[y].value
console.log(test);
var query = "qp.questions"+i+"answers."+y+".value";
doc.update({_id: req.body.questionId}, { '$set': {query : req.body.answerValue} });
console.log(doc.qp.questions[i].answers[y].value);
doc.save().then(() => res.send({questionId: req.body.questionId,answerId: req.body.answerId,answerValue: req.body.answerValue}))
}
}
}
}
})
.catch(error => console.log(error))