如何解决spring mongo 查询根据匹配条件更新数组元素
如何使用仅基于以下内容的 spring mongo 查询条件。
我不想使用 spring mongo save 方法,即使它执行 upsert 因为应用程序在多线程环境中运行,所以只有指定的值应该更新,其余的值不会改变。
假设文档如下:
{
"dept": "FY","companyName": "TIS","id":"112234","contacts": [{
"name": "Jeff","phone": "222 - 572 - 8754"
},{
"name": "Joe","phone": "456 - 875 - 4521"
},{
"name": "Alex","phone": "789 - 875 - 4521"
}
]
}
根据 id 和传递给 update 方法的数组列表,联系人列表应该更新。
让我们基于 id=112234 并将联系人列表传递给更新方法,基于它应该更新的联系人姓名。
"contacts": [{
"name": "Jeff","phone": "111 - 000 - 123"
},{
"name": "Joe","phone": "980 - 546 - 0000"
}
]
最终的 mongo json 文档应该更新如下:
{
"dept": "FY","phone": "111 - 000 - 123"
},"phone": "980 - 546 - 0000"
},"phone": "789 - 875 - 4521"
}
]
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。