地理位置处理时mongo geonear支持【转】

http://blog.youkuaiyun.com/huangrunqing/article/details/9112227
要使用MongoTemplate查询地理位置字段附近的人员记录,可以按照以下步骤进行: 1. **确保文档中有地理位置字段**:在MongoDB中,地理位置字段通常使用GeoJSON格式存储,例如Point类型。 2. **创建MongoTemplate实例**:确保你已经配置好了MongoTemplate实例。 3. **构建查询**:使用`near`操作符来查找指定地理位置附近的人员记录。 以下是一个示例代码,展示了如何使用MongoTemplate查询地理位置字段附近的人员记录: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.geo.GeoJsonPoint; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.NearQuery; import org.springframework.data.mongodb.core.query.Query; import org.springframework.stereotype.Service; import java.util.List; @Service public class PersonService { @Autowired private MongoTemplate mongoTemplate; public List<Person> findNearbyPersons(double longitude, double latitude, double maxDistance) { // 构建地理位置点 GeoJsonPoint point = new GeoJsonPoint(longitude, latitude); // 构建NearQuery NearQuery nearQuery = NearQuery.near(point).maxDistance(maxDistance, org.springframework.data.mongodb.core.geo.Metrics.KILOMETERS); // 构建MongoDB查询 Query query = Query.query(new Criteria().nearSphere("location").geometry(point).maxDistance(maxDistance * 1000)); // 距离单位换为米 // 执行查询 return mongoTemplate.find(query, Person.class); } } ``` 在这个示例中: - `Person`类是一个包含地理位置字段`location`的文档类。 - `findNearbyPersons`方法接受经度、纬度和最大距离作为参数,并返回附近的人员记录。 - 使用`NearQuery`构建地理位置查询,并使用`mongoTemplate.find`执行查询。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值