弹性GeoHash查询 - 聚合过滤器

时间:2017-12-01 10:37:14

标签: elasticsearch geohashing

我正在尝试查询弹性索引,其中查询结果是只有一个匹配文档的地理位置列表。

我可以使用以下内容获得所有地理哈希及其文档计数的简单列表:

{ "size" : 0, "aggregations" : { "boundingbox" : { "filter" : { "geo_bounding_box" : { "location" : { "top_left" : "34.5, -118.9", "bottom_right" : "33.3, -116." } } }, "aggregations":{ "grid" : { "geohash_grid" : { "field": "location", "precision": 4 } } } } } }

但是我无法找出正确的语法来过滤查询,我能得到的最接近的是:

这失败了503 org.elasticsearch.search.aggregations.bucket.filter.InternalFilter cannot be cast to org.elasticsearch.search.aggregations.InternalMultiBucketAggregation

"aggregations":{ "grid" : { "geohash_grid" : { "field": "location", "precision": 4 } }, "grid_bucket_filter" : { "bucket_selector" : { "buckets_path" :{ "docCount" : "grid" //Also tried `"docCount" : "doc_count"` }, "script" : "params.docCount == 1" } } }

400 No aggregation found for path [doc_count]

失败

"aggregations":{ "grid" : { "geohash_grid" : { "field": "location", "precision": 4 } }, "grid_bucket_filter" : { "bucket_selector" : { "buckets_path" :{ "docCount" : "doc_count" }, "script" : "params.docCount > 1" } } }

如何根据geohash网格中的doc_count进行过滤?

1 个答案:

答案 0 :(得分:1)

您需要这样做,即桶选择器管道应指定为geohash_grid的子聚合。另外,您需要使用_count代替doc_count(请参阅here):

{
  "aggregations": {
    "grid": {
      "geohash_grid": {
        "field": "location",
        "precision": 4
      },
      "aggs": {
        "grid_bucket_filter": {
          "bucket_selector": {
            "buckets_path": {
              "docCount": "_count"
            },
            "script": "params.docCount > 1"
          }
        }
      }
    }
  }
}