mongo 数据库索引
- 索引的作用
- 索引的语法
索引的作用
索引可以对查询的高效执行起到支持。如果没有索引,MongoDB必须进行全表扫描,即扫描集合中的每个文档,来选择符合查询条件的文档。如果一个适当的索引存在于一个查询中,MongoDB可以使用索引限制必须检查文档的数量。
索引通常能够极大的提高查询的效率。在系统中使用查询时,应该考虑建立相关的索引。在MongoDB中创建索引相对比较容易。
索引是一种数据结构,他搜集一个集合中文档特定字段的值。MongoDB的查询优化器能够使用这种数据结构来快速的对集合(collection)中的文档(collection)进行寻找和排序.准确来说这些索引是通过B-Tree索引来实现的。
在命令行中,可以通过调用ensureIndex()函数来建立索引,该函数指定一个到多个需要索引的字段。
一旦集合在某一个字段上建立索引后,对该字段的随机查询的访问速度会很快。如果没有索引,MongoDB会在遍历所有的键值对,然后去对应检查相关的字段。
索引的用法
创建索引
db.userInfo.ensureIndex({username: 1});
创建复合索引
db.userInfo.ensureIndex({username: 1, age: -1});
唯一索引
db.test.ensureIndex({"userid":1},{"unique":true})
一些细节
1和-1的区别:1为升序,-1为降序