Хе-хе, нет проблем :-).

аюсь отфильтровать пустые сегменты в блоке агрегации фильтров, и я получаю ошибку отasticsearch. без этого ответ огромен, так как я запрашиваю много метрик и вложенную агрегацию (для простоты это часть большого запроса)

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 (я, например, страна UK - в двух документах нет поля "x"), не возвращать область страны клиенту ,

Ответы на вопрос(1)

Ваш ответ на вопрос