MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Wywołania Mongoose do geoNear z punktami GeoJSON jako parametry zapytania nie działają

Problem polegał na nieprawidłowym użyciu maxDistance. Poniższe wyrażenie zadziałało.


Branch.geoNear({type: "Point", coordinates: [0.0776590, -33.7797590]}, {
  spherical: true, 
  maxDistance: 1 / 6378137, 
  distanceMultiplier: 6378137
})
  .then(function (doc) {
    console.log(doc);
    process.exit();
  });


Mongoose: branches.ensureIndex({ location: '2dsphere' }) { safe: undefined, background: true }  
Mongoose: branches.geoNear(0.077659) -33.779759 { distanceMultiplier: 6378137, lean: true, maxDistance: 1.567855942887398e-7, spherical: true } 
[]

Teraz zapytanie poprawnie wykrywa, że ​​dwa dokumenty w kolekcji nie znajdują się w promieniu 1 metra od lokalizacji, której dotyczy zapytanie. Zapytanie o lokalizację bliżej domu również daje nam oczekiwane wyniki.


Branch.geoNear({type: "Point", coordinates: [153.027117, -27.468515]}, {
  spherical: true, 
  maxDistance: 1 / 6378137, 
  distanceMultiplier: 6378137
})
  .then(function (doc) {
    console.log(doc);
    process.exit();
  });

Mongoose: branches.ensureIndex({ location: '2dsphere' }) { safe: undefined, background: true }  
Mongoose: branches.geoNear(153.027117) -27.468515 { distanceMultiplier: 6378137, lean: true, maxDistance: 1.567855942887398e-7, spherical: true } 
[ { dis: 0.0026823704060803567,
    obj: 
     { name: 'A',
       _id: 533200e49ba06bec37c0cc22,
       location: [Object],
       __v: 0 } } ]

Rozwiązanie?

Dokumentacja MongoDb dotycząca geoNear stwierdza, że ​​jeśli używasz obiektu geoJSON, maxDistance powinno być podawane w metrach, a w radianach, jeśli używasz par współrzędnych.

To albo źle, albo moje rozumienie tego jest błędne.

Jak widać powyżej, zamiast określać 1 metr dla maxDistance, jest on podawany w radianach.



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Indeks MongoDB/Mongoose przyspiesza czy spowalnia zapytanie?

  2. php agregacji mongodb

  3. Zapisywanie przedmiotów w Mongoose dla pętli za pomocą metod schematu

  4. Drukowanie daty MongoDB z PHP

  5. Powłoka MongoDB i serwer nie pasują do siebie