【问题标题】:How can I find nearby place with latitude and longitude in mongodb?如何在mongodb中找到附近经纬度的地方?
【发布时间】:2014-11-03 19:06:58
【问题描述】:

我对 mongodb 和 golang 非常陌生。我有一个名为“myplace”的集合,它有以下文件 place_name、城市、纬度、经度。我的问题是某个地方的用户并搜索附近的地方。如何查询 mongodb 以查找附近的位置。也在 golang 中。

我的文档结构

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

提前致谢

【问题讨论】:

  • 您好,您可以插入文档结构以及您找到的内容吗?
  • @yogesh 我不知道怎么找到

标签: mongodb go mgo


【解决方案1】:

您好,对于您的情况,我认为您应该将上面的文档更改如下

    {
    "_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 click here

对 golang 感到抱歉,因为我对 golang 不太了解

为 Go 语言

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 golang 对我来说是新的,对于我来说学习 golang 需要时间,也许你应该尝试或等待一些 golang 专家并将 mongo 查询转换为 golang。
  • 我认为对于地球上的位置,您需要使用 2dsphere 而不是 2d
【解决方案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}

【讨论】:

    猜你喜欢
    • 2020-08-29
    • 1970-01-01
    • 1970-01-01
    • 2019-08-31
    • 1970-01-01
    • 2021-10-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多