MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Comment puis-je trouver un endroit à proximité avec latitude et longitude dans mongodb ?

Salut Pour votre cas, je pense que vous devriez changer le document ci-dessus comme ci-dessous

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

Après cela, indexez les documents ci-dessus comme ci-dessous

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

Si l'indexation s'exécute correctement, écrivez la requête suivante pour découvrir les documents à proximité

db.location.find({loc: {$near:[51,-114]}})

pour plus d'aide, vous devriez vous référer à mongo $near et $geoNear cliquez ici

et désolé pour golang car je n'en sais pas plus sur golang

pour 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)