一、索引基础
db.user.ensureIndex({"username":1})
db.user.dropIndex({"username":1})
数字 1 表示 username 键的索引按升序存储,-1 表示age 键的索引按照降序方式存储。
db.user.ensureIndex({"username":1, "age":-1})
该索引被创建后,基于 username 和 age 的查询将会用到该索引,或者是基于 username 的查询也会用到该索引,但是只是基于 age 的查询将不会用到该复合索引。因此可以说, 如果想用到复合索引,必须在查询条件中包含复合索引中的前 N 个索引列。然而如果查询条件中的键值顺序和复合索引中的创建顺序不一致的话,MongoDB 可以智能的帮助我们调整该顺序,以便使复合索引可以为查询所用。如:
db.user.find({"age": 30, "username": "stephen"})
随着集合的增长,需要针对查询中大量的排序做索引。如果没有对索引的键调用 sort,
MongoDB 需要将所有数据提取到内存并排序。因此在做无索引排序时,如果数据量过大以致无法在内存中进行排序,此时 MongoDB 将会报错。
二、唯一索引
db.user.ensureIndex({"userid":1},{"unique":true})
E11000 duplicate key error index: user.user.$userid_1 dup key: { : 5.0 }
E11000 duplicate key error index: user.user.$userid_1 dup key: { : null }
db.user.dropIndex({"userid":1})
db.user.ensureIndex({"userid":1},{"unique":true })
db.user.ensureIndex({"userid":1,"age":1},{"unique":true})
如果在为已有数据的文档创建索引时,可以执行下面的命令,以使 MongoDB 在后台创建索引,这样的创建时就不会阻塞其他操作。但是相比而言,以阻塞方式创建索引,会使整个创建过程效率更高,但是在创建时MongoDB 将无法接收其他的操作。