-->

How does MongoEngine handle Indexes (creation, upd

2019-04-29 19:52发布

问题:

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,

回答1:

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.



回答2:

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.