我是Mongoose的新手所以考虑到这一点......
我正在尝试更新文档中的数据但没有成功。 下面的代码按照我的预期标识了文档,并按预期更改了模型。但是更新的模型没有保存到MongoDB,我无法解释为什么...... (也许我应该使用findOneAndUpdate指令,但这样的零碎工作更容易理解。)
UserModel.findOne({memberID: req.params.memberID}, function(err, foundObject) {
if(err) {
console.log('ERROR PUT:/updateUser -> ' + err);
res.status(500).send();
} else {
if(!foundObject) {
console.log('ERROR - PUT:/updateUser, No such record -> ' + req.params.memberID);
res.status(500).send();
} else {
console.log("1 :" + foundObject.info.fName);
if(req.body.fName)
foundObject.info.fName = req.body.fName;
console.log("2 :" + foundObject.info.fName);
foundObject.update(function(err, updatedObject) {
if(err) {
console.log('ERROR - PUT:/updateUser, SAVE FAIL -> ' + err);
res.status(500).send();
} else {
res.status(200).send(updatedObject);
}
});
}
}
});
Postman(我用来测试)的输出是 { “好的”:1, “nModified”:0, “n”:1 } 并且对数据库的直接控制台查询显示没有变化。
答案 0 :(得分:1)
可以试试这个。
UserModel.findOneAndUpdate({memberID: req.params.memberID}, {$set: {"info.fName" : req.body.fName}}, {new: true})
.exec(function (error, updatedUser) {
if (error) {
return res.status(400).send({msg: 'Update failed'});
}
return res.status(200).send(updatedUser);
});
N.B:确保 req.params.memberID 和 req.body.fName 正确