sql >> Database teknologi >  >> NoSQL >> MongoDB

Hvordan kan jeg finde nærliggende sted med breddegrad og længdegrad i mongodb?

Hej Til din sag synes jeg, at du skal ændre ovenstående dokument som nedenfor

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

Derefter indekseres ovenstående dokumenter som nedenfor

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

Hvis indeksering udføres korrekt, så skriv følgende forespørgsel for at finde ud af dokumenter i nærheden

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

for mere hjælp bør du henvise denne mongo $near og $geoNear klik her

og undskyld golang, for jeg ved ikke mere om golang

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


  1. tidsserier og aggregeringsramme (mongo)

  2. Overvågning af Percona Server til MongoDB - Nøglemålinger

  3. azur funktion (node) kalder mongodb afsluttes uden fejl, men intet kommer tilbage fra forespørgslen

  4. Kan jeg bruge MongoDB som erstatning for CoreData på iOS?