gpt4 book ai didi

elasticsearch - Elasticsearch过滤器/计数嵌套字段

转载 作者:行者123 更新时间:2023-12-02 22:19:28 26 4
gpt4 key购买 nike

我的文档带有如下所示的嵌套字段:

...
"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"
}
}
}
}
}

现在我切换到elasticserach 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中

关于elasticsearch - Elasticsearch过滤器/计数嵌套字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39485196/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com