【问题标题】:bucket_script inside filter aggregation throws error过滤器聚合中的 bucket_script 引发错误
【发布时间】:2017-10-11 13:26:14
【问题描述】:

我正在尝试过滤过滤器聚合块中的空存储桶,但我从 elasticsearch 收到错误消息。没有这个,响应是巨大的,因为我正在查询很多指标和嵌套聚合(为简单起见,这是更大查询的一部分)

GET index/type/_search?ignore_unavailable
{
  "size": 0,
  "aggs": {
    "groupby_country": {
      "terms": {
        "field": "country",
        "size": 2000
      },
      "aggs": {
        "exists__x__filter": {
          "filter": {
            "bool": {
              "filter": [
                {
                  "exists": {
                    "field": "x"
                  }
                }
              ]
            }
          },
          "aggs": {
            "sum": {
              "sum": {
                "script": "def val = doc['x'].value; if(val>0) Math.min(val , 20000)"
              }
            },
            "average_distinct": {
              "bucket_script": {
                "buckets_path": {
                  "count": "_count"
                },
                "script": "return params.count "
              }
            }
          }
        }
      }
    }
  }
}

弹性响应:

{
  "error": {
    "root_cause": [],
    "type": "reduce_search_phase_exception",
    "reason": "[reduce] ",
    "phase": "fetch",
    "grouped": true,
    "failed_shards": [],
    "caused_by": {
      "type": "class_cast_exception",
      "reason": "org.elasticsearch.search.aggregations.bucket.filter.InternalFilter cannot be cast to org.elasticsearch.search.aggregations.InternalMultiBucketAggregation"
    }
  },
  "status": 503
}

我想要做的是: 如果对于给定的国家/地区桶,没有字段 x(例如,英国国家 - 2 个文档没有“x”字段) 不要将国家/地区桶返回给客户端。

【问题讨论】:

  • 我不明白你想用bucket_script做什么...
  • @AndreiStefan- 我已添加说明(如果仍不清楚,请告诉我)

标签: elasticsearch elasticsearch-5


【解决方案1】:

为此,您需要一个 bucket_selector,并且脚本略有不同 aa 并放置在更高的级别:

{
  "size": 0,
  "aggs": {
    "groupby_country": {
      "terms": {
        "field": "country",
        "size": 2000
      },
      "aggs": {
        "exists__x__filter": {
          "filter": {
            "bool": {
              "filter": [
                {
                  "exists": {
                    "field": "x"
                  }
                }
              ]
            }
          },
          "aggs": {
            "sum": {
              "sum": {
                "script": "def val = doc['x'].value; if(val>0) Math.min(val , 20000)"
              }
            }
          }
        },
        "average_distinct": {
          "bucket_selector": {
            "buckets_path": {
              "count": "exists__x__filter._count"
            },
            "script": "params.count > 0"
          }
        }
      }
    }
  }
}

【讨论】:

  • 呵呵,没问题:-)。
猜你喜欢
  • 2020-07-26
  • 2022-01-17
  • 1970-01-01
  • 1970-01-01
  • 2015-09-17
  • 2014-02-02
  • 2017-03-09
  • 1970-01-01
  • 2016-07-27
相关资源
最近更新 更多