5 elasticsearch nest elasticsearch-net
我正在使用 Nest 来查询 Elasticsearch,并且我已经为我的搜索编写了以下查询:
var searchResponse = _elasticClient.Search<AdDocument>(s => s
.Query(q => q
.Bool(b => b
.Must(m => m
.MultiMatch(mm => mm
.Fields(f => f.Field(p => p.Title, 1.5).Field(p => p.Description))
.Query("MyKeyword")
.Fuzziness(Fuzziness.Auto)
)
)
.Filter(fi => fi
.Bool(fb => fb
.Must(m => m.Range(r => r.Field(f => f.NoOfBedrooms == 3)),
m => m.Range(r => r.Field(f => f.NoOfBathrooms == 2)),
m => m.Range(r => r.Field(f => f.Price > 2000))
)
)
)
)
)
);
Run Code Online (Sandbox Code Playgroud)
我想要实现的是根据传入的过滤器动态构建此查询。如何使用Object Initializer编写此查询?
例如,我想在查询外部创建这三个范围过滤器,并将它们放入 3 个对象中,例如rangeFilter1,rangeFilter2然后rangeFilter3在查询内部使用逻辑 AND (&&) 将它们组合起来。
这是对象初始值设定项语法:
var boolQuery = new BoolQuery
{
Must = new QueryContainer[]
{
new MultiMatchQuery
{
Fields = Field<AdDocument>(p => p.Title, 1.5).And<AdDocument>(p => p.Description),
Query = "MyKeyword",
Fuzziness = Fuzziness.Auto
}
},
Filter = new QueryContainer[]
{
new TermQuery { Field = Field<AdDocument>(f => f.NoOfBedrooms), Value = 3 } &&
new TermQuery { Field = Field<AdDocument>(f => f.NoOfBathrooms), Value = 2 } &&
new NumericRangeQuery { Field = Field<AdDocument>(p => p.Price), GreaterThan = 2000 }
}
};
var searchResponse = _elasticClient.Search<AdDocument>(new SearchRequest<AdDocument>
{
Query = boolQuery
});
Run Code Online (Sandbox Code Playgroud)
这将产生以下 JSON DSL:
{
"query": {
"bool": {
"must": [
{
"multi_match": {
"query": "MyKeyword",
"fuzziness": "AUTO",
"fields": [
"title^1.5",
"description"
]
}
}
],
"filter": [
{
"bool": {
"must": [
{
"term": {
"noOfBedrooms": {
"value": 3
}
}
},
{
"term": {
"noOfBathrooms": {
"value": 2
}
}
},
{
"range": {
"price": {
"gt": 2000.0
}
}
}
]
}
}
]
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1296 次 |
| 最近记录: |