首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >elasticsearch GEO搜索按距离从近到远排序

elasticsearch GEO搜索按距离从近到远排序
EN

Stack Overflow用户
提问于 2017-06-20 15:27:40
回答 1查看 525关注 0票数 0

一个映射address属性:idnametypelocation。搜索映射:

代码语言:javascript
复制
{
  "address": {
    "properties": {
      "id": {
        "type": "long"
      },
      "type": {
        "type": "long"
      },
      "name": {
        "type": "string"
      },
      "location": {
        "type": "geo_point"
      }
    }
  }
}

搜索命令(过滤address.type = 1distance = 100km):

代码语言:javascript
复制
XGET /_search
{
  "query": {
    "filtered": {
      "query": {
        "match": {
          "type": 1
        }
      },
      "filter": {
        "geo_distance": {
          "distance": "100km",
          "location": {
            "lat": 24.46667,
            "lon": 118.1
          }
        }
      }
    }
  }
}

我想搜索匹配type = 1和地理位置distance = 100km;的地址,并且想要得到order by distance ASC的结果。如何解决这个问题?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-20 16:57:51

由于您是基于距离进行排序的,因此我将匹配查询移到了布尔过滤器中。

这应该是可行的

代码语言:javascript
复制
{
    "query": {
        "bool": {
            "must": [{
                    "geo_distance": {
                        "distance": "1000000km",
                        "location": {
                            "lat": 24.46667,
                            "lon": 118.1
                        }
                    }
                },
                {
                    "term": {
                        "type": {
                            "value": 1
                        }
                    }
                }
            ]
        }
    },
    "sort": {
        "_geo_distance": {
            "location": "24.46667,118.1",
            "order": "asc"
        }
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44646518

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档