Я уверен, что здесь ответили несколько раз, но давайте возьмем ваш конкретный пример.
Создайте индекс
PUT lalit
{
"mappings": {
"properties": {
"model": {
"type": "text",
"fields": {
"keyword": {
"type": "keyword"
}
}
},
"color": {
"type": "text",
"fields": {
"keyword": {
"type": "keyword"
}
}
}
}
}
}
Введите несколько документов
POST lalit/_doc
{"color":"red","model":"bmw"}
POST lalit/_doc
{"color":"blue","model":"bmw"}
POST lalit/_doc
{"color":"red","model":"vw"}
POST lalit/_doc
{"color":"green","model":"vw"}
POST lalit/_doc
{"color":"blue","model":"ford"}
Применить комбинацию терминов agg + a фильтрующих терминов agg
GET lalit/_search
{
"size": 0,
"aggs": {
"all_models": {
"terms": {
"field": "model.keyword"
}
},
"all_colors": {
"terms": {
"field": "color.keyword"
}
},
"model_filtered_colors": {
"filter": {
"term": {
"model.keyword": "vw"
}
},
"aggs": {
"actual_aggs": {
"terms": {
"field": "color.keyword"
}
}
}
}
}
}
Выход
"aggregations" : {
"model_filtered_colors" : {
"doc_count" : 2,
"actual_aggs" : {
"doc_count_error_upper_bound" : 0,
"sum_other_doc_count" : 0,
"buckets" : [
{
"key" : "green",
"doc_count" : 1
},
{
"key" : "red",
"doc_count" : 1
}
]
}
},
"all_models" : {
"doc_count_error_upper_bound" : 0,
"sum_other_doc_count" : 0,
"buckets" : [
{
"key" : "bmw",
"doc_count" : 2
},
{
"key" : "vw",
"doc_count" : 2
},
{
"key" : "ford",
"doc_count" : 1
}
]
},
"all_colors" : {
"doc_count_error_upper_bound" : 0,
"sum_other_doc_count" : 0,
"buckets" : [
{
"key" : "blue",
"doc_count" : 2
},
{
"key" : "red",
"doc_count" : 2
},
{
"key" : "green",
"doc_count" : 1
}
]
}
}
model_filtered_colors
дает вам все vw
с по цвету, в то время как другие 2 агрегации дают вам общие данные по всем показателям (без фильтра vw
).