springmvc mongodb 地理范围查询

引子

现在工作中经常会遇到查询附近XX之类的问题,我最近在工作中也遇到了这样的问题,所以在这里和大家分享一下。

springmvc mongodb 查询附近xx

分两步实现:
1、创建2D索引
    创建2D索引的具体方法大家可以另外去查询一些相关的资料。我这里用的是mongodb的图形界面工具mongoVUE,我是在工具上加的2D索引,用起来比较简单。
首先,数据里面有一个二维数组,用于存放经纬度数据,如下图

这里写图片描述

然后,以location为基础创建2D索引,鼠标放在表上—右键—add index,如下图:

这里写图片描述

2D索引创建成功,如下图:

这里写图片描述

2、代码实现如下:
public List<Yues> getYuesByDistance(int currentPage, int pageSize, String classid, int distance, String key, double lat, double lng) {
        /*//测试用
        lng = 114.08408007659;
        lat = 22.541434936575;*/

        if(distance==0) return null;
        distance = distance==0?ConstantUtil.YUES_DICTIVITY_DISTANCE:distance;

        Criteria ct = new Criteria().where("isPubliced").is(true);
        //1、类型
        if(!StringUtils.isEmpty(classid)){
            ct = ct.andOperator(Criteria.where("classid").is(classid));
        }
        //2、模糊查询
        if(key!=null&&!StringUtils.isEmpty(key.trim())){
            Pattern pattern = Pattern.compile("^.*" + key+ ".*$", Pattern.CASE_INSENSITIVE); 
            ct = ct.where("title").regex(pattern);
        }
        //3、距离
        Query query = new Query(ct);
        Point location = new Point(lng, lat);
        NearQuery mNearQuery = NearQuery.near(location);
        mNearQuery.query(query);
        mNearQuery.with(new PageRequest(currentPage-1, pageSize));
        mNearQuery.spherical(true);
        mNearQuery.maxDistance(distance/ConstantUtil.EARTH_RADIUS);
        GeoResults<Yues> geoNear = mongoTemplate.geoNear(mNearQuery, Yues.class, classname);

        List<Yues> list = new ArrayList<Yues>();
        for (GeoResult<Yues> geoResult : geoNear.getContent()) {
            Yues yues = geoResult.getContent();
            list.add(yues);
        }

        return list;
    }

然后我们就能实现查询附近xx了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值