Elasticsearch搜索附近的人

String lat = request.getParameter("lat");
String lon = request.getParameter("lon");

if (Strings.isNotEmpty(lat) && Strings.isNotEmpty(lon)) {

    SearchRequestBuilder srb = elasticSearchClient.prepareSearch("weidif").setTypes("product");

    //查询数量,1000条
    srb.setFrom(0).setSize(1000);

    //查询相距小于等于50KM数据
    FilterBuilder builder = geoDistanceRangeFilter("location")
            .point(Double.parseDouble(lon), Double.parseDouble(lat))
            .lte(50 + "km");

    srb.setPostFilter(builder);

    GeoDistanceSortBuilder sort = SortBuilders.geoDistanceSort("location");
    sort.unit(DistanceUnit.METERS);
    sort.order(SortOrder.ASC);
    sort.point(Double.parseDouble(lon), Double.parseDouble(lat));
    srb.addSort(sort);

    SearchResponse searchResponse = srb.execute().actionGet();

    SearchHits hits = searchResponse.getHits();
    SearchHit[] searchHists = hits.getHits();

    for (SearchHit hit : searchHists) {
        String name = (String) hit.getSource().get("name");
        HashMap<String, Object> location = (HashMap<String, Object>) hit.getSource().get("location");
        BigDecimal geoDis = new BigDecimal((Double) hit.getSortValues()[0]);
        Map<String, Object> hitMap = hit.getSource();
        hitMap.put("geoDistance", geoDis.setScale(0, BigDecimal.ROUND_HALF_DOWN));
        System.out.println(name + location + ",相距:" + hit.getSource().get("geoDistance") + "m");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值