有没有推荐的方法来使用 django nonrel 对 mongodb 进行自定义查询?
我有一个完整的站点设置并运行良好,现在我只是添加了一些地理空间索引和查询,并想知道是否已经支持地理空间查询,或者是否有使用定制的最佳实践方法询问?
有没有推荐的方法来使用 django nonrel 对 mongodb 进行自定义查询?
我有一个完整的站点设置并运行良好,现在我只是添加了一些地理空间索引和查询,并想知道是否已经支持地理空间查询,或者是否有使用定制的最佳实践方法询问?
我找到了这个问题的一个答案,如果有更好的答案,请告诉我。
如此处所述,将您的对象分配给 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()
然后你可以像这样进行原始查询:
MyModel.objects.raw_query({'loc' : {'$near' : [50,50]}})
我猜另一种方法是直接访问 pymongo: http ://api.mongodb.org/python/1.10%2B/examples/geo.html
最后我结束了这个查询:
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