Node.js Mongoose MongoDB:更新嵌套数组中的对象
我有下面的模式Node.js Mongoose MongoDB:更新嵌套数组中的对象,node.js,mongodb,mongoose,Node.js,Mongodb,Mongoose,我有下面的模式 var UserSchema = new Schema({ emp_no: Number, skills: [{ skill: { type: Schema.Types.ObjectId, ref: 'Skill' }, startDate: {type: Date}, }] }); 然后我尝试更新一个特定技能的起始日期。我尝试了几种不同的方法,其中之一是: User.findOne({emp_no: req.body
var UserSchema = new Schema({
emp_no: Number,
skills: [{
skill: {
type: Schema.Types.ObjectId,
ref: 'Skill'
},
startDate: {type: Date},
}]
});
然后我尝试更新一个特定技能的起始日期。我尝试了几种不同的方法,其中之一是:
User.findOne({emp_no: req.body.emp_no}, function (err, user) {
user.update( {'skills._id': 123}, {'$set': {
'skills.$.startDate': req.body.startDate
}}
}
此特定代码给出:err:'无法使用部件(skills of skills.\u id)遍历元素
实际对象看起来像
{
"_id" : ObjectId("5469753de27a7c082203fd0a"),
"emp_no" : 123,
"skills" : [
{
"skill" : ObjectId("547d5f3021d99d302079446d"),
"startDate" : ISODate("2014-12-02T06:43:27.763Z")
"_id" : ObjectId("547d5f8f21d99d3020794472")
}
],
"__v" : 108
}
知道我做错了什么吗?当您像在这里这样调用模型实例时,第一个参数是应用于该文档的更新操作,因为要更新的文档已经由其\u id
唯一标识
相反,使用可在一个操作中完成此操作:
User.update(
{emp_no: req.body.emp_no, 'skills._id': 123},
{'$set': {
'skills.$.startDate': req.body.startDate
}},
function(err, numAffected) {...}
);
这有帮助吗-?非常感谢,这很有效!我以前也试过,因为我想其他地方出了问题,所以没有得到正确的结果。如何寻找
技能。_id
不在[1,2,3]
中。尝试了{'skills.\u id':{$nin:[1,2,3]}
但没有成功。