我有带有嵌套字段的文档,如下所示:
...
"results": [
{
"id": "1234",
"name": "asdf"
},
{
"id": "5678",
"name": "jklö"
}
],
"ip": "1.2.3.4"
...
嵌套字段的映射如下所示:
"results": {
"type": "nested",
"properties": {
"id": {
"type": "string"
},
"name": {
"type": "string"
}
}
}
在我切换到 elasticsearch 2 之前,我进行了一个带有 aggs 的查询,该查询对没有结果的文档进行了计数。这是查询的聚合部分:
"aggs": {
"no_result": {
"filter": {
"missing": {
"field": "results"
}
},
"aggs": {
"count": {
"value_count": {
"field": "ip"
}
}
}
}
}
现在我切换到elasticsearch 2,它只计算所有文档。我已经尝试了不同的方法,例如计算所有文档和计算结果,以便我可以减去结果,但是
"aggs": {
"results_count": {
"value_count": {
"field": "results"
}
}
}
始终为 0
如何正确过滤/计算嵌套字段?
如果你想计算有结果的文档数量,你可以这样做。
{
"size": 0,
"aggs": {
"count": {
"nested": {
"path": "results"
},
"aggs": {
"top_reverse_nested": {
"reverse_nested": {}
}
}
}
}
}
数量将在 top_reserve_nested doc_count 中
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)