如何在mongodb中找到经纬度附近的地方?

san*_*anu 3 go mongodb mgo

对mongodb和golang来说很新.我有一个名为"myplace"的集合它有以下文件place_name,city,latitude,longitude.我的问题是用户在某个地方并搜索附近的地方.如何查询mongodb以查找附近的位置.也在golang.

我的文档结构

{
    "_id" : ObjectId("544a2147785b707b340ed6c7"),
    "latitude" : 12.36547,
    "longitude" : 1.235689,
    "place_name" : "some_place",
    "city" : "Some city"
}
Run Code Online (Sandbox Code Playgroud)

提前致谢

Yog*_*esh 7

嗨,对于您的情况,我认为您应该更改上面的doc如下

    {
    "_id" : ObjectId("545749dba2b0b4cf603a7546"),
    "city" : "B",
    "placeName" : "A",
    "loc" : {
        "lon" : 51.10682735591432,
        "lat" : -114.11773681640625
    }
}
{
    "_id" : ObjectId("545749f3a2b0b4cf603a7547"),
    "city" : "B1",
    "placeName" : "A1",
    "loc" : {
        "lon" : 51.09144802136697,
        "lat" : -114.11773681640625
    }
}
Run Code Online (Sandbox Code Playgroud)

之后索引上述文件如下

db.collectionName.ensureIndex({loc:"2d"})
Run Code Online (Sandbox Code Playgroud)

如果索引正确执行,则编写以下查询以查找文档附近

db.location.find({loc: {$near:[51,-114]}})
Run Code Online (Sandbox Code Playgroud)

要获得更多帮助,请参考这个mongo $ near和$ geoNear 点击这里

抱歉golang,因为我不太了解golang

对于golang

var places []Place
lat := 51.515614
long := -0.268998
err = coll.Find(bson.M{"loc": bson.M{"$near": []float64{long, lat}, "$maxDistance" :      0.056}}).All(&places)
Run Code Online (Sandbox Code Playgroud)