Подтвердить что ты не робот

Возвращаемое расстояние в результатах elasticsearch?

Мой вопрос похож на этот один.

Просто, есть способ вернуть гео-расстояние, когда НЕ сортируется с _geo_distance?

Обновление: Чтобы уточнить, я хочу, чтобы результаты в случайном порядке и включали расстояние.

4b9b3361

Ответ 1

Да, вы можете, используя поле script.

Например, если у вашего документа есть поле геоточечной области 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

Если вы хотите, чтобы поле _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)"
      }
   }
}
'

Ответ 2

Чтобы вернуть расстояние так же, как и все поля/источник по умолчанию, вы также можете сделать это:

Чтобы избежать сортировки по расстоянию (в первую очередь), просто сортируйте по _score (или независимо от того, что вы хотите отсортировать по результатам).

{
   "sort": [
    "_score",
    {
      "_geo_distance": {
        "location": { 
          "lat":  40.715,
          "lon": -73.998
        },
        "order":         "asc",
        "unit":          "km", 
        "distance_type": "plane" 
      }
    }
  ]
}

Ответ 3

Так как ES 1.3 MVEL отключен по умолчанию, используйте такой запрос, как:

GET some-index/_search
{
  "sort": [
    {
      "_geo_distance": {
        "geo_location": "47.1, 8.1",
        "order": "asc",
        "unit": "m"
      }
    }
  ],
  "query": {
    "match_all": {}
  },
   "script_fields" : {
      "distance" : {
         "lang": "groovy",
         "params" : {
            "lat" : 47.1,
            "lon" : 8.1
         },
         "script" : "doc[\u0027geo_location\u0027].distanceInKm(lat,lon)"
      }
   }
}

см.: "lang": "groovy", часть

Ответ 4

Отличный ответ от DrTech... вот обновленная версия для Elasticsearch 5.x с безболезненным языком script. Я также добавил "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
        }
      }
    }
  }
}'