如何解决更新 MongoDB 文档数组字段中的所有对象
我想做什么
我正在尝试使用 mongoose 更新 MongoDB 文档中字段数组内的所有对象。
我有什么
用户文档
{
id: <ObjectId>,...
notifications: [
{
commissionId: <ObjectId>
commissioner: <ObjectId>
date: ...
description: "You have a new commission!"
},{
commissionId: <ObjectId>
commissioner: <ObjectId>
date: ...
description: "You have a new commission!"
},]
}
我想要的
{
id: <ObjectId>,...
notifications: [
{
commissionId: <ObjectId>
commissioner: <ObjectId>
date: ...
description: "You have a new commission!"
read: true // Add read field with a value of true
},{
commissionId: <ObjectId>
commissioner: <ObjectId>
date: ...
description: "You have a new commission!"
read: true // Add read field with a value of true
},]
}
我正在使用 mongoose,现在我正在使用 findByIdandUpdate
方法。我试过了
使用一种方法来做到这一点,但它只是失败了。
await User.findByIdAndUpdate(
args.userId,{
notifRead: true,$set: {
"notifications.$.read": true,// FAIL "The positional operator did not find the match needed
// from the query."
},},{
new: true,runValidators: true,}
);
有没有办法简单地做到这一点?
解决方法
可以使用 all positional operator $[]
,您可以这样做:
await User.update(
args.userId,{
$set: {
"notifications.$[].read": true,},{
muti: true
}
);
有关详细信息,您可以查看here。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。