如何在MongoDB中使用纬度和经度查找附近的地点?

3

我对mongodb和golang非常不熟悉。我有一个名为“myplace”的集合,它具有以下字段:地点名称、城市、纬度和经度。我的问题是用户在某个地方搜索附近的地点。我该如何查询mongodb以查找附近的地点?同时,在golang中如何实现。

我的文档结构

{
    "_id" : ObjectId("544a2147785b707b340ed6c7"),
    "latitude" : 12.36547,
    "longitude" : 1.235689,
    "place_name" : "some_place",
    "city" : "Some city"
}

Thanks in advance


你好,你能插入文档结构和你发现的内容吗? - Neo-coder
@yogesh 我不知道如何找到。 - sanu
2个回答

8

你好,针对你的情况,我认为你应该按照以下方式更改上述文档:

    {
    "_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
    }
}

接下来按照以下方式对上述文档进行索引

db.collectionName.ensureIndex({loc:"2d"})

如果索引执行正确,则编写以下查询以查找附近的文档。
db.location.find({loc: {$near:[51,-114]}})

如果需要更多帮助,您可以参考Mongo $near和$geoNear的相关文档点击这里

对于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)

请问您能否编写Golang的代码。我尝试了以下方法: var place []Place lat := 51.515614 long := -0.268998 E := 0.00002 err = coll.Find(bson.M{"loc": bson.M{"$near": [long,lat], bson.M{"$maxDistance" : 0.056}}}).All(&place) - sanu
抱歉 @sanu,对于我来说,golang是新的编程语言,学习它需要时间。也许你应该尝试等待一些熟练掌握golang并能将mongo查询转换为golang的人。 - Neo-coder
1
我认为对于地球上的位置,您需要使用2dsphere而不是2d。 - icchanobot

2
这个链接可能会对你有所帮助:https://github.com/mendrugory/Airports MongoDB查询(Python)
def get_closest_airports(lonlat, limit=10):
    """
    Using a raw query it returns the "limit" closest airports.

    :param latlon list:
    :return list of airports:
    """
    return Airport.objects(
        __raw__={"loc": {"$near": {"$geometry": {"type": "Point", "coordinates": lonlat}}}}).limit(limit)

JSON结构如下:

{"city": "Goroka", "tz": "Pacific/Port_Moresby", "name": "Goroka", "dst": "U", "loc": {"type": "Point", "coordinates": [145.391881, -6.081689]}, "country": "Papua New Guinea", "iata/faa": "GKA", "altitude": 5282.0, "icao": "AYGA", "timezone": 10.0, "id": 1}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接