」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何使用 MongoDB Go 驅動程式建立嵌套 OR/AND 查詢?

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

發佈於2025-01-11
瀏覽:127

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

使用MongoDB Go Driver 進行嵌套邏輯查詢

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是預設邏輯運算符,因此無需將其明確包含在query.

透過遵循這些準則,您可以使用 MongoDB 驅動程式在 Go 中高效地建立嵌套 OR/AND 查詢。

最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3