什么是MongoDB索引
索引是一种单独的、物理的对数据库中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的页的逻辑指针清单。索引的作用相当于图书中的目录,可以根据目录中的页码快速找到所需的内容。索引目标是提高数据库的查询效率,没有索引的话,查询会进行全表扫描(scan every docuemtn in a collection),数据量最大时严重降低了查询效率。默认情况下Mongo在一个集合(collection)创建时,自动的对集合的_id创建了唯一索引。
索引类型
单键索引
MongoDB支持所有数据类型中的单个字段索引,并且可以在文档的任何字段上定义。对于单个字段索引,索引键的排序顺序无关紧要,因为MongoDB可以在任一方向读取索引。
单键索引的例子:
db.集合名.createIndex({"字段名":排序方式})
特殊的单键索引过期索引TTL(Time To Live)
TTL索引是MongoDB中一种特殊的索引,可以支持文档在一定时间之后字段过期删除,目前TTL索引只能在单键索引上创建,并且值要为日期类型。
db.集合名.createIndex({"日期字段": 排序方式}, {expireAfterSeconds: 秒数})
复合索引
通常我们需要在多个字段得到基础上搜索表/集合,这是非常频繁的。如果是这种情况,我们可以考虑在MongoDB中使用复合索引。复合索引支持基于多个字段的索引,这扩展了索引的概念并将它们扩展到索引中的更大的域。</