用猫鼬更新嵌套数组

时间:2018-10-25 23:52:24

标签: javascript node.js mongodb mongoose mongodb-query

我正在尝试使用 $ set 更新对象的值,以将 Object 传递给嵌套数组元素,但是该元素tha被更新是第一个元素不是我查询的那个。我不确定自己在做什么错。

模式

const storySchema = new mongoose.Schema({
    //some fields
    stages: [{
        //some fields
        events: [{
            author: {
                type: Schema.Types.ObjectId,
                ref: 'User',
                required: true
            },
            body: {
                type: String,
                required: true,
                trim: true
            }     
        }]
    }]
})

快递更新路线

  Story.findOneAndUpdate({ 'stages.events._id': req.params.eventId }, {
    '$set': {
      'stages.0.events.$': req.body.event
    }
  }, {
    new: true,
    runValidators: true
  })

2 个答案:

答案 0 :(得分:0)

按照@Veeram的建议,我在解决方案中使用了arrayFilters。

这是解决方案。

  Story.findOneAndUpdate({ 'stages.events._id': req.params.eventId }, {
    '$set': {
      'stages.0.events.$[event]': req.body.event
    }
  }, {
    new: true,
    runValidators: true,
    arrayFilters: [{ 'event._id': mongoose.Schema.Types.ObjectId(req.params.eventId) }]
  })

答案 1 :(得分:0)

您可以使用此

 Story.findOneAndUpdate({ 'stages.events._id': req.params.eventId }, {
    '$set': {
      'stages.$.events.$': req.body.event
    }
  }, {
    new: true,
    runValidators: true
  })