我正在尝试使用MongoDB.Driver查询 MongoDB并使用 mongo 投影返回部分结果。
我已经想出了如何在没有投影的情况下进行查询,但不是部分结果。这是我查找结果的功能:
let Find<'a> collectionName (filterDefinition: FilterDefinition<'a>) =
let collection = database.GetCollection<'a> collectionName
collection.Find(filterDefinition).ToEnumerable() |> List.ofSeq
这是我如何称呼它的一个例子:
let findByIdFilter id =
Builders<MyModel>.Filter.Eq((fun s -> s.id), id)
let results = Find collectionName (findByIdFilter id)
假设我的模型是这样的:
type MyInnerModel = {
zInner: bool
}
type MyModel = {
id: ObjectId
x: int
y: double
z: MyInnerModel
}
这些是我的预测:
type MyModelProjection1 = {
id: ObjectId
y: double
}
type MyModelProjection1 = {
id: ObjectId
x: int
z: MyInnerModel
}
如何针对以下场景构建查询:
- 查找
(fun (m: MyModel) -> m.z.zInner = false)
与投影匹配的文档MyModelProjection1
- 查找
(fun (m: MyModel) -> m.x = 5)
与投影匹配的文档MyModelProjection2
- 查找投影到
MyModelProjection1
或的所有文档MyModelProjection2