1
我在弹性搜索中有以下一组嵌套子集(field2是field1的subaggregation,field3是field2的subaggregation)。 然而,事实证明,字段3的术语聚合不会存储没有字段3的文档。如何在elasticsearch中嵌套聚合中填充空和非空字段?
我的理解是我必须使用Missing subaggregation查询来除了术语query for field3之外的那些查询。
但我不知道如何将它添加到下面的查询中以便同时存储。
{
"size": 0,
"aggregations": {
"f1": {
"terms": {
"field": "field1",
"size": 0,
"order": {
"_count": "asc"
},
"include": [
"123"
]
},
"aggregations": {
"field2": {
"terms": {
"field": "f2",
"size": 0,
"order": {
"_count": "asc"
},
"include": [
"tr"
]
},
"aggregations": {
"field3": {
"terms": {
"field": "f3",
"order": {
"_count": "asc"
},
"size": 0
},
"aggregations": {
"aggTopHits": {
"top_hits": {
"size": 1
}
}
}
}
}
}
}
}
}
}
我在2.1.1版本,但不幸的是,新办法不在内部层面上工作看到这个问题https://github.com/elastic/elasticsearch/issues/14882 – user2175783
好的电话。我正在2.2集群上进行测试,并按预期工作。我并不知道2.1.1和之前的错误。我已经更新了我的答案,以澄清在哪个版本中,“missing”选项有效,并包含您提供给错误详细信息的链接。 – BrookeB