[英]uptade nested array with mongoose
我试图更新使用$设置对象的值将对象传递到嵌套数组元素,但该元素塔更新是第一要素不是我查询。 我不确定自己在做什么错。
架构
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
})
按照@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) }]
})
你可以用这个
Story.findOneAndUpdate({ 'stages.events._id': req.params.eventId }, {
'$set': {
'stages.$.events.$': req.body.event
}
}, {
new: true,
runValidators: true
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.