Mongoose MongoDB:更新嵌套数组中的对象

我有以下架构

var UserSchema = new Schema({ emp_no: Number, skills: [{ skill: { type: Schema.Types.ObjectId, ref: 'Skill' }, startDate: {type: Date}, }] }); 

然后我试图更新一个特定技能的startDate。 我尝试了几种不同的方法,其中之一是:

 User.findOne({emp_no: req.body.emp_no}, function (err, user) { user.update( {'skills._id': 123}, {'$set': { 'skills.$.startDate': req.body.startDate }} } 

这个特殊的代码给出了:err:'不能使用部分(skills._id的技能)遍历元素

实际的物体看起来像

 { "_id" : ObjectId("5469753de27a7c082203fd0a"), "emp_no" : 123, "skills" : [ { "skill" : ObjectId("547d5f3021d99d302079446d"), "startDate" : ISODate("2014-12-02T06:43:27.763Z") "_id" : ObjectId("547d5f8f21d99d3020794472") } ], "__v" : 108 

}

任何想法我做错了什么?

当您在模型实例上调用update时,第一个参数是应用于该文档的更新操作,因为要更新的文档已由其_id唯一标识。

相反,使用Model.update在一个操作中完成这一切:

 User.update( {emp_no: req.body.emp_no, 'skills._id': 123}, {'$set': { 'skills.$.startDate': req.body.startDate }}, function(err, numAffected) {...} );