Elasticsearch 过滤器/计算嵌套字段

2024-04-20

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

...
"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(使用前将#替换为@)

Elasticsearch 过滤器/计算嵌套字段 的相关文章

随机推荐