簡體   English   中英

更新mongodb中對象數組的一個元素

[英]update one element of array of objects in mongodb

我有以下文件:

{
  _id: ObjectId('111111111111111111114444'),
  books: [
    {
      id: ObjectId('111111111111111111113333'),
      pictures: []
    },
    {
      id: ObjectId('111111111111111111112222'),
      pictures: []
    }
  ],
  // others attributes
}

我需要做的是在pictures添加一個元素。 請記住,我有documentIddocumentId的 id,而bookIdbooks元素的 Id。

如果我想將元素{description: "nice picture"}1111111111111111111114444一書中的文檔1111111111111111111113333 ,更新后的文檔看起來像

{
  _id: ObjectId('111111111111111111114444'),
  books: [
    {
      id: ObjectId('111111111111111111113333'),
      pictures: [
        {
          description: "nice picture"
        }
      ]
    },
    {
      id: ObjectId('111111111111111111112222'),
      pictures: []
    }
  ],
  // others attributes
}

詢問

  • 管道更新需要 MongoDB >= 4.2
  • 過濾“_id”
  • 如果id=2合並對象,則在書籍上映射,其中圖片包含新元素
  • 否則如果不是id=2不要換書

*我使用 1,2,3 作為 ids(它的代碼相同)

測試代碼在這里

update({"_id" : 1},
[{"$set": 
   {"books": 
     {"$map": 
       {"input": "$books",
        "in": 
        {"$cond": 
          [{"$eq": ["$$book.id", 2]},
           {"$mergeObjects": 
             ["$$book",
               {"pictures": 
                 {"$concatArrays": 
                   ["$$book.pictures", [{"description": "nice picture"}]]}}]},
           "$$book"]},
        "as": "book"}}}}])

編輯

詢問

  • 如果圖片不是數組(或不存在),則創建一個空數組

測試代碼在這里

update({"_id" : 1},
[{"$set": 
    {"books": 
      {"$map": 
        {"input": "$books",
          "in": 
          {"$cond": 
            [{"$eq": ["$$book.id", 2]},
              {"$mergeObjects": 
                ["$$book",
                  {"pictures": 
                    {"$concatArrays": 
                      [{"$cond": 
                          [{"$isArray": ["$$book.pictures"]}, "$$book.pictures",
                            []]},
                        [{"description": "nice picture"}]]}}]},
              "$$book"]},
          "as": "book"}}}}])

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM