Spring Data Elasticsearch 2.1.16:如何获得排序距离?



当您尝试在ES中按距离排序时,结果通常包含匹配项与搜索位置之间的距离:

"hits": {
"total": 3,
"max_score": null,
"hits": [
{
"_index": "circle",
"_type": "doc",
"_id": "7",
"_score": null,
"_source": {
"id": 7,
"coordinates": {
"lon": 112.548443,
"lat": 37.780269
}
},
"sort": [
116.39283058047849
]
},
{
"_index": "circle",
"_type": "doc",
"_id": "5",
"_score": null,
"_source": {
"id": 5,
"coordinates": {
"lon": 112.55061,
"lat": 37.779145
}
},
"sort": [
231.9203763747634
]
}
]

}排序距离包含在sort字段中。我如何获得排序距离在春季日期Elasticsearch 2.1.16,与elasticsearchTemplate?

这是我的代码查询:Page<CircleES> resultPage = elasticsearchTemplate.queryForPage(searchQuery, CircleES.class);

要在2.1.16版本中获取此信息,您需要使用

方法
queryForPage(SearchQuery query, Class<T> clazz, SearchResultMapper mapper)

,并提供一个自定义的SearchResultMapper,从返回的数据中解析所需的信息。

顺便说一句,2.1.16已于2018年10月15日发布,现已不支持。

最新更新