码迷,mamicode.com
首页 > 数据库 > 详细

MongoDB的地理位置索引

时间:2020-02-08 11:24:52      阅读:85      评论:0      收藏:0      [点我收藏+]

标签:如何   个数   新建   高德   重复   自带   inf   附近的店   bsp   

背景

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

技术图片

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

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

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

 技术图片

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

 技术图片

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

 技术图片

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

 技术图片

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

 技术图片

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

 技术图片

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

 技术图片

 

 技术图片

MongoDB的地理位置索引

标签:如何   个数   新建   高德   重复   自带   inf   附近的店   bsp   

原文地址:https://www.cnblogs.com/xubao/p/12275617.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!