mongodb java 地理位置_MongoDB的地理位置索引

wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

背景

我们平常打开一些App的时候,经常有一个“查询周边景点”的功能,如我在高德里面就查询到了附近的景点。

fd1c05b52a96e6c67556f7e2d2d34d21.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

这种计算如果通过普通的关系型数据库,那对服务器和数据库的性能要求就太高了。

我们可以通过MongoDB自带的地址位置索引来实现。

如何使用

前期准备:插入数据

我们先插入四条数据,即店铺的类型,名称和地理位置。注意地理位置的第一个数值表示精度(范围为-100到100),第二个数值表示纬度(范围为-90到90)。

163f78e3b178eda160c1e9fbadaebd8c.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

查询结果

下图的语句是查询在经纬度为50和50位置附近的店铺,但我们看到是报错了,理由是我们要新建字段loc上面的地理索引。

68b67386446af014032e28c31977012a.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

建立地理索引的步骤如下: (也就是在loc字段上面建立地理位置索引)

26cb243cbd869a48d985385d487a6311.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

我们重复执行刚才的语句,发现成功啦。

74c6e948c7ad2fdb602f6de4fd878380.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

现在我们写一个稍微复杂的场景,我们要搜索在位置(50,50)附近的咖啡店,该排序是从近到远排的。

758ffed3dd66619eb2796d1948f690d0.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

我们再写一个更复杂的场景,我们要搜索在位置(50,50)附近的咖啡店,并且距离在37m之内。

c8deec232d9af6220dea6259c8a8c448.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

还有一个参数是limit,控制店铺数量的,如下:

443e98fc1e19c1997084f59f15467c3f.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

aa2e121045a7ac3cd807a5784c417498.pngwAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值