首頁 >後端開發 >Golang >如何使用 MongoDB Go 驅動程式建立嵌套 OR/AND 查詢?

如何使用 MongoDB Go 驅動程式建立嵌套 OR/AND 查詢?

Susan Sarandon
Susan Sarandon原創
2024-12-01 15:33:11274瀏覽

How to Construct Nested OR/AND Queries with the MongoDB Go Driver?

使用MongoDB Go 驅動程式進行巢狀邏輯查詢

MongoDB 查詢通常需要使用巢狀邏輯運算子(AND/OR)來過濾基於文檔的文檔根據多個標準。在 Go MongoDB 驅動程式中,可以使用 bson.D 和 bson.M 類型建構巢狀邏輯查詢。

建構巢狀OR/AND 查詢

建立一個巢狀OR/AND 查詢時,需要使用bson.D 類型來表示外部邏輯運算子(例如$ and),並將bson.E 元素傳遞給它。每個 bson.E 元素代表一個欄位值對,其中欄位名稱可以是邏輯運算子(例如 $or),值可以是 bson.D 或 bson.A(對於陣列)。

巢狀OR/AND 查詢範例

考慮MongoDB查詢:

{
  "$and": {
    "p": 10,
    "$or": {
      "s": 30,
      "a": 1
    }
  }
}

要使用MongoDB 驅動程式在Go 中表示此查詢,可以使用以下程式碼:

filter := bson.D{
    {"p", 10},
    {"$or", bson.A{
        bson.D{{"s", 30}},
        bson.D{{"a", 1}},
    }},
}

在此範例中,bson.D表示外部 $ and 運算符,bson.A 表示嵌套的 $or 運算符。 $or 中的每個 bson.D 代表一個子查詢。

使用 bson.M 進行巢狀查詢

也可以使用 bson.M 型別來表示巢狀查詢。 bson.M 是一個map[string]interface{},可以包含欄位名稱及其對應的值。該值可以是另一個 bson.M 實例,表示巢狀查詢。

例如,上面的查詢可以使用bson.M 表示,如下:

filter := bson.M{
    "p": 10,
    "$or": bson.A{
        bson.M{"s": 30},
        bson.M{"a": 1},
    },
}

建議

  • 要在邏輯運算子中表示數組,請使用bson.A (例如, bson.A{bson.M{"foo": 1}})。
  • $and 是預設邏輯運算符,因此無需在查詢中明確包含它。

透過遵循這些指南,您可以使用 MongoDB 驅動程式在 Go 中有效地建立巢狀 OR/AND 查詢。

以上是如何使用 MongoDB Go 驅動程式建立嵌套 OR/AND 查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn