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

Zná někdo funkční příklad indexu 2dsphere v pymongo?

2dsphere (pymongo.GEOSPHERE) typ indexu funguje pouze v MongoDB 2.4 a novějších. Budete také chtít použít GeoJSON formát pro vaše body. A konečně, operátory geografických dotazů MongoDB jsou citlivé na pořadí, takže budete muset použít SON při použití možností jako $maxDistance. Zde je příklad použití $near :

>>> c = pymongo.MongoClient()
>>> points = c.dbtest.points
>>> points.ensure_index([("loc", pymongo.GEOSPHERE)])
u'loc_2dsphere'
>>> points.insert({'loc': {'type': 'Point', 'coordinates': [40, 5]}})
ObjectId('51b0e508fba522160ce84c3a')
>>> for doc in points.find({"loc" : SON([("$near", { "$geometry" : SON([("type", "Point"), ("coordinates", [40, 5])])}), ("$maxDistance", 10)])}):
...     doc
... 
{u'loc': {u'type': u'Point', u'coordinates': [40, 5]}, u'_id': ObjectId('51b0e508fba522160ce84c3a')}


  1. Dotaz na podpole v documentdb

  2. Problémy s agregačním rámcem SailsJS &MongoDB s vlastními dotazy

  3. Sdílení připojení nativního ovladače Node.js Mongodb

  4. Přidejte uživatele jednoduchého čtení a zápisu v mongo 3.4.1