在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)));