Новое в скоплениях в эластичном поиске. Использование 7.2. Я пытаюсь написать агрегацию на Tree.keyword, чтобы вернуть только количество документов, имеющих ключ, содержащий слово «Ветвь». Я попробовал субагрегации, bucket_selector (который не работает для ключевых строк) и сценарии. У кого-нибудь есть какие-либо идеи или предложения о том, как к этому подойти?
Отображение:
{
"testindex" : {
"mappings" : {
"properties" : {
"Tree" : {
"type" : "text",
"fields" : {
"keyword" : {
"type" : "keyword"
}
}
}
}
}
}
}
Пример запроса, который возвращает все ключи, но мне нужно лишь ограничить возврат ключей с помощью "Ветвь "или, точнее, просто подсчет количества ключей" Ветвь ":
GET testindex/_search
{
"aggs": {
"bucket": {
"terms": {
"field": "Tree.keyword"
}
}
}
}
Возвращает:
{
"took" : 1,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "testindex",
"_type" : "_doc",
"_id" : "1",
"_score" : 1.0,
"_source" : {
"Tree" : [
"Car:76",
"Branch:yellow",
"Car:one",
"Branch:blue"
]
}
}
]
},
"aggregations" : {
"bucket" : {
"doc_count_error_upper_bound" : 0,
"sum_other_doc_count" : 0,
"buckets" : [
{
"key" : "Car:76",
"doc_count" : 1
},
{
"key" : "Branch:yellow",
"doc_count" : 1
},
{
"key" : "Car:one",
"doc_count" : 1
},
{
"key" : "Branch:blue",
"doc_count" : 1
}
]
}
}
}