Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How does MongoEngine handle Indexes (creation, update, removal)?

Best practice question about setting Mongo indexes. Mongoengine, the Python ORM wrapper, allows you to set indexes in the Document meta class.

When is this meta class introspected and the index added? Can I build a collection via a mongoengine Document class and then add an index after the fact?

If I remove the index from the meta class, is the index automatically removed from the corresponding collection?

Thanks,

like image 778
Ben Avatar asked Oct 13 '11 18:10

Ben


2 Answers

You can add an index at any time and ensureIndex will be called behind the scenes so it will be added if it doesn't exist.

If you remove an index from the meta - you will have to use pymongo or the shell to remove the index.

like image 64
Ross Avatar answered Nov 14 '22 22:11

Ross


MongoEngine provides a programming construct to maintain all indexes from your python application.It uses metadata on collection class to define all your indexes. Here is an example

class User(Document):
    meta = {        
    'indexes': [
    {
         'fields': ['+name']                   
    },
    {
         'fields': ['#email']
    }]             
}

The User class defined above declares two indexes: 1. name (sort order) and 2. email (hashed). MongoEngine creates each declared index at the first upsert operation. These indexes are created on the collection via a createIndex/ensureIndex call . MongoEngine attempts to create these indexes every time a document is inserted into the collection.

like image 40
VISHAL KUMAWAT Avatar answered Nov 14 '22 22:11

VISHAL KUMAWAT