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

时间:2014-12-02 22:53:28

标签: node.js mongodb mongoose

我有以下架构

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          
    }}
}

这个特殊的代码给出:错误:'不能使用部分(skill._id技能)来遍历元素

实际对象看起来像

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

}

任何想法我做错了什么?

1 个答案:

答案 0 :(得分:17)

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

相反,使用Model.update在一个操作中执行此操作:

_id