地理位置索引 2d索引

地址位置索引:将一些点的位置存储在mongodb中,创建索引后,可以按照位置来查找其他点
子分类:
1、2d索引:平面地理位置索引,用于存储和查找平面上的点。
2、2dsphere索引:球面地理位置索引,用于存储和查找球面上的点。
查找方式:
1、查找距离某个点一定距离内的点。
2、查找包含在某区域内的点。
  比如当前打车软件比较火,当确定某个乘客的点的时候,服务器需要确定某个范围内的出租车,接收乘客的搭车请求,这个时候就可以使用mongodb的地理位置索引去完成这样的需求
  比如在使用团购网站时,距离我们最近的餐馆,也可以使用mongodb的地理位置索引去完成。

mongodb的地理位置索引十分强大,可以节省其他数据库所要花费的大量时间来完成应用。



2d索引
创建方式:
db.collection.ensureIndex({w:'2d'})
位置表示方式:经纬度[经度,纬度] 取值范围:经度[-
180180] 纬度[-90 90
> db.location.ensureIndex({'w':'2d'})
{
    "createdCollectionAutomatically" : true,
    "numIndexesBefore" : 1,
    "numIndexesAfter" : 2,
    "ok" : 1
}

 

插入几条数据
> db.location.insert({w:[1,1]})
WriteResult({ "nInserted" : 1 })
> db.location.insert({w:[1,2]})
WriteResult({ "nInserted" : 1 })
> db.location.insert({w:[3,2]})
WriteResult({ "nInserted" : 1 })
> db.location.insert({w:[100,100]})
WriteResult({ "nInserted" : 1 })
> db.location.insert({w:[180,100]})
WriteResult({ "nInserted" : 1 })
我们看到经度超过180会报错,纬度超过90,但没报错,对这种点在查询中会有不可预知的错误,所以不应该插入这种点
> db.location.find()
{ "_id" : ObjectId("5b6b6fa572ff7510af7fc783"), "w" : [ 1, 1 ] }
{ "_id" : ObjectId("5b6b6fa872ff7510af7fc784"), "w" : [ 1, 2 ] }
{ "_id" : ObjectId("5b6b6fab72ff7510af7fc785"), "w" : [ 3, 2 ] }
{ "_id" : ObjectId("5b6b703772ff7510af7fc788"), "w" : [ 180, 80 ] }
所以插入这些点



2d索引的查询方式有两种
1、$near查询:查询距离某个点最近的点。
2、$geoWithin查询:查询某个形状内的点。
> db.location.find({w:{$near:[1,1]}})
{ "_id" : ObjectId("5b6b6fa572ff7510af7fc783"), "w" : [ 1, 1 ] }
{ "_id" : ObjectId("5b6b6fa872ff7510af7fc784"), "w" : [ 1, 2 ] }
{ "_id" : ObjectId("5b6b6fab72ff7510af7fc785"), "w" : [ 3, 2 ] }
{ "_id" : ObjectId("5b6b703772ff7510af7fc788"), "w" : [ 180, 80 ] }
我们看到所有点都返回了,原因是near会返回一百个最近的点
我们可以使用maxDistance来限制最远的点
> db.location.find({w:{$near:[4,2],$maxDistance:10}})
{ "_id" : ObjectId("5b6b6fab72ff7510af7fc785"), "w" : [ 3, 2 ] }
{ "_id" : ObjectId("5b6b6fa872ff7510af7fc784"), "w" : [ 1, 2 ] }
{ "_id" : ObjectId("5b6b6fa572ff7510af7fc783"), "w" : [ 1, 1 ] }
我们看到只返回了3个点,这种简单的,这里不支持minDistance



$geoWithin查询
形状的表示
1、$box:矩形,使用
  {$box:[[<x1>,<y1>],[<x2>,<y2>]]}表示
  都是坐标,第一个坐标表示矩形的左边界,第二个坐标表示矩形的右边界
2、$center:圆形,使用
  {$center:[[<x1>,<y1>],r]}
  第一个表示圆心位置,第二个代表半径
3、$polygon:多边形,使用
  {$polygon:[<x1>,<y1>],[<x2>,<y2>],[<x3>,<y3>]}表示
  每个数组代表一个坐标点,这些点代表一个多边形

 

 

posted @ 2018-08-09 06:50  wzndkj  阅读(914)  评论(0编辑  收藏  举报