sql >> Databasteknik >  >> NoSQL >> MongoDB

Hur kan jag hitta en plats i närheten med latitud och longitud i mongodb?

Hej För ditt fall tycker jag att du ska ändra ovanstående dokument enligt nedan

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

Efter det indexerar ovanstående dokument enligt nedan

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

Om indexeringen körs korrekt, skriv följande fråga för att ta reda på dokument i närheten

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

för mer hjälp bör du hänvisa till denna mongo $near och $geoNear klicka här

och förlåt för golang för jag vet inte mer om golang

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)


  1. Hur man optimerar prestanda för MongoDB

  2. hur man uppdaterar och infogar poster i php med mongodb

  3. MongoDB och Mongoid i produktion

  4. Konvertera enkel MySQL-databas till en NoSQL-lösning