在C#中编写bool和聚合查询
Write bool and aggregate query in C#
伙计们,我想编写嵌套查询,它将使用过滤器获取不同的结果。
我想使用 Nest
在 c# 中编写以下部分 Elasticsearch
代码。
GET /index/type/_search
{
"query": {
"bool": {
"must": [
{
"terms": {
"ID": [ "5","6" ]
}
},
{
"terms": {
"ProjectID": [ "54"]
}
}
]
}
},
"aggs": {
"my_fields": {
"terms": {
"field": "ID",
"size": 0
}
}
}
}
我是 Elasticsearch.Help 的新手,无法用 lambda 表达式编写它。我写了一些代码,但不知道如何在查询中添加方括号
var ElasticSearchNetQuery = new { aggs = new { distinctRespId = new { cardinality = new { field = "RespID" }, query = new { @bool = new { must= new { } } } }, size = 10000 } };
var results = client.Search<object>(sd => sd
.Index("<index name>")
.Type("<type name>")
.Query(q => q
.Bool(b => b
.Must(
m => m.Terms("ID", new[] { "5", "6" }),
m => m.Terms("ProjectID", new[] { "54" }))))
.Aggregations(a => a
.Terms("my_fields", t => t
.Field("ID")
.Size(0)));
伙计们,我想编写嵌套查询,它将使用过滤器获取不同的结果。
我想使用 Nest
在 c# 中编写以下部分 Elasticsearch
代码。
GET /index/type/_search
{
"query": {
"bool": {
"must": [
{
"terms": {
"ID": [ "5","6" ]
}
},
{
"terms": {
"ProjectID": [ "54"]
}
}
]
}
},
"aggs": {
"my_fields": {
"terms": {
"field": "ID",
"size": 0
}
}
}
}
我是 Elasticsearch.Help 的新手,无法用 lambda 表达式编写它。我写了一些代码,但不知道如何在查询中添加方括号
var ElasticSearchNetQuery = new { aggs = new { distinctRespId = new { cardinality = new { field = "RespID" }, query = new { @bool = new { must= new { } } } }, size = 10000 } };
var results = client.Search<object>(sd => sd
.Index("<index name>")
.Type("<type name>")
.Query(q => q
.Bool(b => b
.Must(
m => m.Terms("ID", new[] { "5", "6" }),
m => m.Terms("ProjectID", new[] { "54" }))))
.Aggregations(a => a
.Terms("my_fields", t => t
.Field("ID")
.Size(0)));