Мой вопрос похож на этот один.
Просто, есть способ вернуть гео-расстояние, когда НЕ сортируется с _geo_distance?
Обновление: Чтобы уточнить, я хочу, чтобы результаты в случайном порядке и включали расстояние.
Мой вопрос похож на этот один.
Просто, есть способ вернуть гео-расстояние, когда НЕ сортируется с _geo_distance?
Обновление: Чтобы уточнить, я хочу, чтобы результаты в случайном порядке и включали расстояние.
Да, вы можете, используя поле 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)"
}
}
}
'
Чтобы вернуть расстояние так же, как и все поля/источник по умолчанию, вы также можете сделать это:
Чтобы избежать сортировки по расстоянию (в первую очередь), просто сортируйте по _score (или независимо от того, что вы хотите отсортировать по результатам).
{
"sort": [
"_score",
{
"_geo_distance": {
"location": {
"lat": 40.715,
"lon": -73.998
},
"order": "asc",
"unit": "km",
"distance_type": "plane"
}
}
]
}
Так как 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",
часть
Отличный ответ от 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
}
}
}
}
}'