MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

Wie kann ich einen nahe gelegenen Ort mit Breiten- und Längengrad in Mongodb finden?

Hallo. Ich denke, in Ihrem Fall sollten Sie das obige Dokument wie folgt ändern

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

Danach Indizierung der obigen Dokumente wie unten

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

Wenn die Indizierung ordnungsgemäß ausgeführt wird, schreiben Sie die folgende Abfrage, um Dokumente in der Nähe herauszufinden

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

für weitere Hilfe sollten Sie auf diese mongo $near und $geoNear verweisen hier klicken

und Entschuldigung für Golang, weil ich nicht mehr über Golang weiß

für 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)