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

Come creare una query personalizzata usando django-nonrel e mongodb

Ho trovato una risposta a questa domanda, fammi ora se ce n'è una migliore.

Come documentato qui, assegna i tuoi oggetti a MongoDBManager - http://django-mongodb-engine.github.com/mongodb-engine/cool-stuff.html#included-mongodb-batteries

from django_mongodb_engine.contrib import MongoDBManager

class MyModel(models.Model):
    objects = MongoDBManager()

Quindi puoi eseguire query grezze come questa:

MyModel.objects.raw_query({'loc' : {'$near' : [50,50]}})

Un approccio diverso, immagino, sarebbe quello di passare direttamente a pymongo:http://api.mongodb.org/python/1.10%2B/examples/geo.html

Alla fine ho finito con questa domanda:

nearest = MyModel.objects.raw_query(
    {'loc' : {
         '$within' :{ #within .05 degrees of lat/lon
                    '$center' : [{'long' : long,'lat' : lat}, .05]
                    }
      })[:10] #get up to 10 results