如何解决在mongodb,节点中按兄弟名称在数组中插入元素
{
"_id": {
"$oid": "60e544a5e0762b0b2ef6657e"
},"user0": "a","details": [{
"name": "jon","things": [{
"name": "car","work": "travel"
},{
"name": "phone","work": "network"
}]
},{
"name": "steve","things": [{
"what": "car",{
"what": "phone","work": "network"
}]
}]
}
我想在“things”数组中插入一个名称为“steve”的对象 现在我正在这样做,但不起作用
collection.updateOne({_id:docs[0]._id},{$push:{"details.$[]":{things:req.body.data}}});
解决方法
您想使用 arrayFilters,它使您能够使用查询更新数组中的特定元素,在本例中为名称为“steve”的元素:
db.collection.update(
{
_id:docs[0]._id
},{
$push: {
"details.$[elem].things": req.body.data
}
},{
arrayFilters: [
{
"elem.name": "steve"
}
]
})
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。