使用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}, }, }
建議
透過遵循這些準則,您可以使用 MongoDB 驅動程式在 Go 中高效地建立嵌套 OR/AND 查詢。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3