sql >> Databáze >  >> NoSQL >> MongoDB

Volání Mongoose do geoNear s body GeoJSON jako parametry dotazu nefungují

Problém byl v nesprávném použití maxDistance. Následující výraz fungoval.


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 } 
[]

Nyní dotaz správně zjistí, že dva dokumenty ve sbírce nejsou ve vzdálenosti do 1 metru od dotazovaného umístění. Očekávané výsledky nám také poskytuje dotaz na umístění blíže k domovu.


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 } } ]

Řešení?

MongoDb dokumentace geoNear uvádí, že pokud používáte geoJSON objekt, maxDistance by měla být v metrech a v radiánech, pokud používáte páry souřadnic.

Toto je buď špatné, nebo tomu nerozumím.

Jak můžete vidět výše, místo určení 1 metru pro maxDistance se dodává v radiánech.



  1. brew install php56-mongo Příkaz nefunguje

  2. Yii Emongodocuments poblíž dotazů ignorujících maxDistance

  3. Jak najít kolekci kódu pomocí regulárního výrazu a složitých kritérií pomocí ovladače Java MongoDB?

  4. Jak získat velikost jednoho dokumentu v Mongodb?