首頁 > 後端開發 > Golang > 如何使用內部數組中的值更新文檔

如何使用內部數組中的值更新文檔

王林
發布: 2024-02-10 11:09:09
轉載
912 人瀏覽過

如何使用內部數組中的值更新文檔

php小編香蕉為你帶來了一個關於如何使用內部陣列中的值更新文件的實用指南。在開發過程中,我們經常需要從一個陣列中獲取資料並將其更新到文件中。本文將介紹使用PHP的內部陣列中的值來更新文件的方法,這種方法簡單而靈活,能夠幫助我們更有效率地處理資料更新任務。無論你是初學者還是有經驗的開發者,希望這篇文章能為你帶來一些有價值的知識和技巧。讓我們馬上開始吧!

問題內容

我被困在一些看起來並不複雜的事情上,也許有些東西是我沒有想到或沒有看到的。

擁有(很多)包含物件數組的文檔,例如:

{
    "_id": "ox1",
    "results": [
        {
            "id": "a1",
            "somethingelse": "aa",
            "value": 1
        },
        {
            "id": "a2",
            "somethingelse": "bb",
            "value": 2
        },
        {
            "id": "a3",
            "somethingelse": "cc",
            "value": 3
        }
    ],
    "total": 0
},
{
    "_id": "ox2",
    "results": [
        {
            "id": "a1",
            "somethingelse": "aa",
            "value": 44
        },
        {
            "id": "a4",
            "somethingelse": "bb",
            "value": 4
        },
        {
            "id": "a5",
            "somethingelse": "aa",
            "value": 5
        }
    ],
    "total": 0
},
{
    "_id": "ox3",
    "results": [
        {
            "id": "a2",
            "somethingelse": "aa",
            "value": 1
        },
        {
            "id": "a3",
            "somethingelse": "aa",
            "value": 4
        },
        {
            "id": "a4",
            "somethingelse": "aa",
            "value": 5
        }
    ],
    "total": 0
}
登入後複製

我想要一個 updatemany 查詢來更新所有具有「結果」的文檔,其中包含:

  • “id”:“a1”
  • "somethingelse": "aa"

#透過包含「id」:「a1」和「somethingelse」:「aa」的「結果」的值增加其「總計」

所以在我們的例子中: 「0x1」的結果包含「id」:「a1」和「somethingelse」:「aa」的「值」為 1 -> 我希望它的「總數」增加1

「0x2」的結果包含「id」:「a1」和「somethingelse」:「aa」的「值」為 44 -> 我希望它的「總數」增加 44

“0x3”不符合條件

用 go 寫,開頭如下:

// Here I filter only the documents meeting the condition
filter := bson.D{{
    Key: "results,
    Value: bson.D{{
        Key: "$elemMatch",
        Value: bson.D{
            {Key: "id", Value: "a1"},
            {Key: "somethingElse", Value: "aa"},
        }},
    }},
}

// This is where it gets tricky
addTotal := bson.M{
    "$set": bson.D{{
        Key: "total",
        Value: bson.D{{
            Key: "$sum",
            Value: bson.A{
                "$total",
                bson.M{ 
                    // How can I get the "value" from the right object from the array ?
                },
            },
        }},
    }},
}
登入後複製

這可能嗎? 我還沒有找到太多關於內部/嵌入式查詢的資訊。

解決方法

db.collection.updatemany(filter, update, options) 中的update 參數可以是更新文件或聚合管道( doc)。

更新文件僅包含更新運算子表達式,看起來像這樣:

{
   <operator1>: { <field1>: <value1>, ... },
   <operator2>: { <field2>: <value2>, ... },
   ...
}
登入後複製

值不能引用文件中的欄位。

雖然聚合管道較先進,可以引用文件中的欄位。這是使用聚合管道執行此操作的一種方法:

db.collection.updatemany(
  { results: { $elemmatch: { id: 'a1', somethingelse: 'aa' } } },
  [
    {
      $set: {
        total: {
          $let: {
            vars: {
              items: {
                $filter: {
                  input: '$results',
                  as: 'item',
                  cond: {
                    $and: [
                      { $eq: ['$$item.id', 'a1'] },
                      { $eq: ['$$item.somethingelse', 'aa'] },
                    ],
                  },
                },
              },
            },
            in: { $add: ['$total', { $sum: '$$items.value' }] },
          },
        },
      },
    },
  ]
);
登入後複製

翻譯成go程式碼:

filter := bson.M{
    "results": bson.M{
        "$elemMatch": bson.M{
            "id":            "a1",
            "somethingElse": "aa",
        },
    },
}

vars := bson.M{
    "items": bson.M{
        "$filter": bson.M{
            "input": "$results",
            "as":    "item",
            "cond": bson.M{
                "$and": bson.A{
                    bson.M{"$eq": bson.A{"$$item.id", "a1"}},
                    bson.M{"$eq": bson.A{"$$item.somethingElse", "aa"}},
                },
            },
        },
    },
}

update := bson.A{
    bson.M{
        "$set": bson.M{
            "total": bson.M{
                "$let": bson.M{
                    "vars": vars,
                    "in": bson.M{
                        "$add": bson.A{"$total", bson.M{"$sum": "$$items.value"}},
                    },
                },
            },
        },
    },
}
登入後複製

以上是如何使用內部數組中的值更新文檔的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板