【问题标题】:Elasticsearch - Query field against aggregationElasticsearch - 针对聚合的查询字段
【发布时间】:2018-11-19 14:38:09
【问题描述】:

我正在探索使用 elasticsearch 查询和聚合数据的便利性。但我无法在单个查询中对数据进行透视和聚合,如下所示:

考虑数据:

有没有办法查询下面的结果 如下所示对值进行旋转和聚合:

要求的结果:

{  
   {  
      "A":a1,
      "B":b1,
      "Value":3
   },
   {  
      "A":a1,
      "B":b2,
      "Value":3
   },
   {  
      "A":a2,
      "B":b2,
      "Value":4
   },
   {  
      "A":a1,
      "B":b3,
      "Value":11
   }
}

【问题讨论】:

    标签: elasticsearch elasticsearch-aggregation


    【解决方案1】:

    是的,您可以为AB 嵌套两个terms 聚合,就像这样,您将得到您所期望的结果:

    {
      "size": 0,
      "aggs": {
        "A": {
          "terms": {
            "field": "A"
          },
          "aggs": {
            "B": {
              "terms": {
                "field": "B"
              },
              "aggs": {
                "value_sum": {
                  "sum": {
                    "field": "Value1"
                  }
                }
              }
            }
          }
        }
      }
    }
    

    【讨论】:

    • 谢谢瓦尔。它确实有效。只需为总和添加一个标签。
    猜你喜欢
    • 2020-12-21
    • 1970-01-01
    • 1970-01-01
    • 2011-12-25
    • 2019-09-24
    • 2022-01-18
    • 2018-07-13
    • 1970-01-01
    • 2020-02-18
    相关资源
    最近更新 更多