1、对象创​​建注意事项,ElasticSearch搜索附近的API,支持数组、字符串、对象的形式,如下:

"lat,lon" "location":"40.715,-74.011"  字符串的形式
"location": {"lat":40.715,"lon":-74.011} 对象的形式
"location":[-74.011,40.715] 数组的形式

​ 具体的使用,查看官方ES-API ES官方文档

2、位置的数据映射类型需要设置为geo_point,地理位置的数据需要提供经纬度信息,当经纬度不合法时,ES会拒绝新增文档。

"position":{"type":"geo_point"}

​3、ElasticSearch支持4种关于位置的过滤器,如下:

geo_distance: 查找距离某个中心点距离在一定范围内的位置
geo_bounding_box: 查找某个长方形区域内的位置
geo_distance_range: 查找距离某个中心的距离在min和max之间的位置
geo_polygon: 查找位于多边形内的地点。

​4、执行搜索,代码如下:

/**
* position:对象字段
* latitude: 纬度
* longitude:经度
* maxDistance:搜索半径
* DistanceUnit.KILOMETERS:设置搜索半径单位 km 
*/
GeoDistanceQueryBuilder distanceQueryBuilder = QueryBuilders.geoDistanceQuery("position")
                .point(latitude, longitude).distance(maxDistance, DistanceUnit.KILOMETERS);
boolQueryBuilder.must(distanceQueryBuilder);
searchSourceBuilder.postFilter(boolQueryBuilder);

5、设置按照地理位置远近正序排序

// 按照位置远近 正序排序
GeoDistanceSortBuilder distanceSortBuilder = SortBuilders.geoDistanceSort("position",latitude,longitude).point(latitude,longitude)
.unit(DistanceUnit.KILOMETERS).order(SortOrder.ASC);
searchSourceBuilder.sort(distanceSortBuilder);

Last modification:August 19, 2021
如果觉得我的文章对你有用,请随意赞赏