[英]Updating a nested object in a document using mongoose
我一直在尝试使用findOneAndUpdate()
方法更新 Mongodb 文档中的特定 object ,但没有任何运气。 这就是我的收藏品的样子
{
_id: new ObjectId("61da0ab855483312e8f4483b"),
products: [
{
createdAt: 2022-01-08T22:05:44.635Z,
_id: new ObjectId("61da0ab855483312e8f4483c"),
productCode: 'otf',
productName: 'facebookmeta',
claims: [Array],
permissions: []
},
{
createdAt: 2022-01-08T22:05:44.635Z,
_id: new ObjectId("61da0ab855483312e8f4483f"),
productCode: '4pf',
productName: 'twitteroauth',
claims: [Array],
permissions: [Array]
}
],
__v: 0
}
当我尝试这样的事情时。 我试图根据其产品代码找到一个奇异的 object 并更新 object
ProductModel.findOneAndUpdate({productCode: userData.productCode}, dataToBeUpdated, {new: true})
它返回一个
Performing an update on the path '_id' would modify the immutable field '_id
我怀疑 MongoDB 正在对集合应用查询条件并返回匹配文档的结果,因此它可能返回两个对象,这可能是我遇到错误的原因,但我可能是错的。
我如何有效地将其指向正确的 object 并执行更新
MongoDB 支持使用位置运算符($)对子文档进行单级深度更新。
db.collection_name.update({
_id: ObjectId("61da0ab855483312e8f4483b"),
"products.productCode": "4pf"
},
{
"$set": {
"products.$.productName": "twitteroauth name updated"
}
})
在上述更新子句中,$ 将在运行时被子文档的匹配索引替换。
例如 $ 将在运行时被值 1 替换,因为 "products.productCode": "4pf" 条件
请注意以下几点:
附加参考: https://docs.mongodb.com/manual/reference/operator/update/positional/
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.