一、准备数据
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);