【问题标题】:Multiple aggregations in ElasticsearchElasticsearch 中的多个聚合
【发布时间】:2017-11-27 07:43:45
【问题描述】:

我想对两个字段进行术语聚合。我不想要子聚合,但我想要两个不同的桶组中的结果,就像我对这两个字段进行两个单独的查询一样。是否可以将这两个查询合二为一?

第一个查询:

{
    "size" : 0,
    "aggs" : {
        "brands" : {
            "terms" : {
                "field" : "my_field1",
                "size" : 15
            },
            "aggs" : {
                "my_field_top_hits1" : {
                    "top_hits" : {
                        "size" : 1
                    }
                }
            }
        }
    }
}

第二次查询:

{
    "size" : 0,
    "aggs" : {
        "brands" : {
            "terms" : {
                "field" : "my_field2",
                "size" : 15
            },
            "aggs" : {
                "my_field_top_hits2" : {
                    "top_hits" : {
                        "size" : 1
                    }
                }
            }
        }
    }
}

【问题讨论】:

    标签: elasticsearch elasticsearch-aggregation


    【解决方案1】:

    除非我遗漏了一些明显的东西,否则你只需要这样做:

    {
      "size": 0,
      "aggs": {
        "brands_field1": {
          "terms": {
            "field": "my_field1",
            "size": 15
          },
          "aggs": {
            "my_field_top_hits1": {
              "top_hits": {
                "size": 1
              }
            }
          }
        },
        "brands_field2": {
          "terms": {
            "field": "my_field2",
            "size": 15
          },
          "aggs": {
            "my_field_top_hits1": {
              "top_hits": {
                "size": 1
              }
            }
          }
        }
      }
    }
    

    【讨论】:

    • 同意@Andrei
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-07-26
    • 1970-01-01
    • 2018-10-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多