繁体   English   中英

使用 mongoose 更新文档中的嵌套 object

[英]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" 条件

请注意以下几点:

  1. 您必须将数组字段作为查询文档的一部分。
  2. 位置运算符不能用于嵌套数组内的更新。

附加参考: https://docs.mongodb.com/manual/reference/operator/update/positional/

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM