sql >> Base de Datos >  >> NoSQL >> MongoDB

Cómo hacer una consulta personalizada usando django-nonrel y mongodb

Encontré una respuesta a esta pregunta, déjame ahora si hay una mejor.

Como se documenta aquí, asigne sus objetos 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()

Entonces puedes hacer consultas sin procesar como esta:

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

Supongo que un enfoque diferente sería ir directamente a pymongo:http://api.mongodb.org/python/1.10%2B/examples/geo.html

Finalmente terminé con esta consulta:

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