【问题标题】:Mongoose MongoDB: updating objects in a nested arrayMongoose MongoDB:更新嵌套数组中的对象
【发布时间】:2015-01-31 08:35:30
【问题描述】:

我有以下架构

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: 'cannot use the part (skills of 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

}

任何想法我做错了什么?

【问题讨论】:

标签: node.js mongodb mongoose


【解决方案1】:

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

改为使用Model.update 一次性完成所有操作:

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

【讨论】:

  • 非常感谢,这行得通!我过去曾尝试过,但我猜其他地方出了问题,所以没有得到正确的结果
  • 如何在[1, 2, 3] 之外查找skills._id。试过 {'skills._id': {$nin: [1, 2, 3]}} 但没用。
猜你喜欢
  • 2023-01-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多