弹性搜索结果中的返回距离?

Yeg*_*eps 34 geolocation elasticsearch

我的问题是,类似这样的一个.

简单来说,有没有办法在不使用_geo_distance进行排序时返回地理距离?

更新:为了澄清,我希望结果是随机顺序并包括距离.

DrT*_*ech 42

是的,您可以使用脚本字段.

例如,假设您的doc有一个名为geo-point的字段location,您可以使用以下命令:

(注意这\u0027只是一个逃脱的单引号,所以\u0027location\u0027真的'location')

curl -XGET 'http://127.0.0.1:9200/geonames/_search?pretty=1'  -d '
{
   "script_fields" : {
      "distance" : {
         "params" : {
            "lat" : 2.27,
            "lon" : 50.3
         },
         "script" : "doc[\u0027location\u0027].distanceInKm(lat,lon)"
      }
   }
}
'

# [Thu Feb 16 11:20:29 2012] Response:
# {
#    "hits" : {
#       "hits" : [
#          {
#             "_score" : 1,
#             "fields" : {
#                "distance" : 466.844095463887
#             },
#             "_index" : "geonames_1318324623",
#             "_id" : "6436641_en",
#             "_type" : "place"
#          },
... etc
Run Code Online (Sandbox Code Playgroud)

如果您还希望_source返回该字段,则可以按如下方式指定:

curl -XGET 'http://127.0.0.1:9200/geonames/_search?pretty=1'  -d '
{
   "fields" : [ "_source" ],
   "script_fields" : {
      "distance" : {
         "params" : {
            "lat" : 2.27,
            "lon" : 50.3
         },
         "script" : "doc[\u0027location\u0027].distanceInKm(lat,lon)"
      }
   }
}
'
Run Code Online (Sandbox Code Playgroud)

  • 在弹性5.x中,6.x应该使用`arcDistance(lat,lon)`或`planeDistance(lat,lon)`方法. (4认同)

Jet*_*tte 12

DrTech给出了很好的答案......这里是Elasticsearch 5.x的更新版本,脚本语言是无痛的.我还添加了"store_fields"以包含_source在结果中:

curl -XGET 'http://127.0.0.1:9200/geonames/_search?pretty=1'  -d '
{
  "stored_fields" : [ "_source" ],
  "script_fields" : {
    "distance" : {
      "script" : {
        "inline": "doc['location'].arcDistance(params.lat,params.lon) * 0.001",
        "lang": "painless",
        "params": {
          "lat": 2.27,
          "lon": 50.3
        }
      }
    }
  }
}'
Run Code Online (Sandbox Code Playgroud)


Lud*_*ord 8

要像所有默认字段/来源一样返回距离,您也可以这样做:

为了避免按距离排序(主要是),您只需先按_score(或任何您想要的结果排序)排序.

{
   "sort": [
    "_score",
    {
      "_geo_distance": {
        "location": { 
          "lat":  40.715,
          "lon": -73.998
        },
        "order":         "asc",
        "unit":          "km", 
        "distance_type": "plane" 
      }
    }
  ]
}
Run Code Online (Sandbox Code Playgroud)

  • 此解决方案也适用于禁用脚本支持,就像在许多托管服务器上一样。谢谢! (2认同)