Возвращает только размер сегмента запроса агрегации - Elasticsearch - PullRequest
0 голосов
/ 15 апреля 2019

Я использую запрос агрегации наasticsearch 2.1, вот мой запрос:

"aggs": { 
    "atendimentos": {
      "terms": {
        "field": "_parent",
        "size" : 0
      }
    }
  }

Возврат такой:

"aggregations": {
        "atendimentos": {
            "doc_count_error_upper_bound": 0,
            "sum_other_doc_count": 0,
            "buckets": [
                {
                    "key": "1a92d5c0-d542-4f69-aeb0-42a467f6a703",
                    "doc_count": 12
                },
                {
                    "key": "4e30bf6d-730d-4217-a6ef-e7b2450a012f",
                    "doc_count": 12
                }.......

Возвращает 40000 сегментов, поэтому у меня много сегментов в этой агрегации, я просто хочу вернуть размер сегментов, но я хочу что-то вроде этого:

buckets_size: 40000

Ребята, а как вернуть только размер ковша?

Ну, спасибо всем.

Ответы [ 2 ]

0 голосов
/ 15 апреля 2019
{
    "aggs" : {
        "type_count" : {
            "cardinality" : {
                "field" : "type"
            }
        }
    }
}

Подробнее о Агрегирование кардинальности

0 голосов
/ 15 апреля 2019

попробуйте этот запрос:

POST index/_search
{
  "size": 0,
  "aggs": {
    "atendimentos": {
      "terms": {
        "field": "_parent"
      }
    },
    "count":{
      "cardinality": {
        "field": "_parent"
      }
    }
  }
}

Он может вернуть что-то подобное:

"aggregations": {
    "aads": {
      "doc_count_error_upper_bound": 0,
      "sum_other_doc_count": 0,
      "buckets": [
        {
          "key": "aa",
          "doc_count": 1
        },
       {
          "key": "bb",
          "doc_count": 1
        }
      ]
    },
    "count": {
      "value": 2
    }
  }

РЕДАКТИРОВАТЬ: Подробнее здесь - https://www.elastic.co/guide/en/elasticsearch/reference/2.1/search-aggregations-metrics-cardinality-aggregation.html

...