1

以下の http リクエストのように: TERM "service_project" aggr に基づいて、2 つの別の SUM aggr "service_hour_price" と "service_part_price" があります。Elasticsearch Nest を使用して同じことを行うことはできますか?

      "aggs": {
        "3": {
          "terms": {
            "field": "service_project",
            "size": 50,
            "order": {
              "1": "desc"
            }
          },
          "aggs": {
            "1": {
              "sum": {
                "field": "service_hour_price"
              }
            },
            "2": {
              "sum": {
                "field": "servic_part_price"
              }
            }
          }
        }
    }

これで、次のように、That Term Aggr で SUM Aggr ベースを 1 つだけ使用できます。

                return s.Aggregations(a => a
                .Terms("names", st => st
                    .Field(o => o.service_project)
                    .OrderDescending("sum")
                    .Size(term_count)
                    .Aggregations(aa => aa
                        .Sum("sum", m => m
                            .Field(o => o.service_hour_price)))));
4

1 に答える 1

0

あなたはもうすぐそこにいます:

s.Aggregations(a => a
    .Terms("3", t => t
        .Field("service_project")
        .Size(50)
        .OrderDescending("1")
        .Aggregations(aa => aa
            .Sum("1", sum => sum.Field("service_hour_price"))
            .Sum("2", sum => sum.Field("service_part_price")))
    ));

それが役に立てば幸い。

于 2015-11-17T19:29:09.530 に答える