首页 > 编程知识 正文

mongodb 联合唯一索引,mongodb聚合索引

时间:2023-05-04 21:14:32 阅读:182333 作者:1871

本章内容:

创建复合索引排序前缀索引交叉点其他注意事项MongoDB支持复合索引compound indexes。 复合索引包含对聚集文档中多个字段[1]的引用。 下图显示了两个字段的复合索引示例。

userid字段(升序)和score字段(降序)的复合索引。 索引首先按userid字段排序,然后按score字段排序。

[1] MongoDB的复合索引限制在http://www.Sina.com/http://www.Sina.com /以内。

复合索引可以支持多个字段中的查询匹配。

一.创建复合索引要创建复合索引,请使用以下操作模板:

在db.collection.create index ({ field 1: type,field2: type2, } )索引规范中,此字段的值描述字段的索引类型。 例如,值32指定按升序对记录条目进行排序的索引。 值个字段指定按降序对记录条目进行排序的索引。 有关其他索引类型的信息,请参见索引类型。

1

不能创建类型为-1的复合索引。 如果尝试创建包含散列索引字段的复合索引,则会显示错误消息。

考虑一个名为products的集合,其中包含以下文档:

{'_id': ObjectId,' item': 'Banana ',' category': ['food ',' produce ',' grocery'],' produce ' grocery'] 'type': 'cases'}按以下操作,在重要和http://www.Sina.com/http://www.Sina.com /字段中

db.products.create index { ' item ' :1,' stock': 1 }复合索引中字段的顺序很重要。 首先按哈希索引字段中的值对索引进行排序,然后在item字段中的每个值内按字段中的值对索引进行排序详情请参照排序顺序。

复合索引不仅可以在所有索引字段中支持匹配查询,还可以在索引字段的前缀(索引的第一个子集)中支持匹配查询。 这意味着索引支持查询stock字段和item字段和3358www.Sina.com/字段。

db.products.find(item: ) banana ) ) db.products.find(item: ) banana ),stock: ) $gt:

二、排序索引按照升序(1)或降序(1)-1 )的排序顺序存储对字段的引用。 对于单字段索引,字段的排序顺序并不重要,因为MongoDB可以在任意方向上遍历索引。 但是,对于复合索引,排序顺序决定了索引能否支持排序操作。

例如,一个名为events的集合,其中包含字段为itemstock的文档。 APP应用程序开始查询操作。 查询返回的结果首先按username值按升序排序,然后按date值按降序排序。 这意味着:

db.events.find ().sort (username :1,date: -1 } ) )或查询的结果首先按username值的降序排序,然后按date值的升序排序。 例如:

db.events.find ().sort ) username:-1

, date: 1 } )

以下索引可以支持这两种排序操作:

db.events.createIndex( { "username" : 1, "date" : -1 } )

但是,以上索引不能支持按username值升序,然后按date值升序排序,例如:

db.events.find().sort( { username: 1, date: 1 } )

有关排序顺序和复合索引的更多信息,请参见使用索引对查询结果进行排序。

 

三、索引前缀

索引前缀是索引字段的起始子集。例如,考虑以下复合索引:

{ "item": 1, "location": 1, "stock": 1 }

索引具有以下索引前缀:

{ item: 1 }{ item: 1, location: 1 }

对于复合索引,MongoDB可以使用索引来支持对索引前缀的查​​询。这样,MongoDB可以将索引用于以下字段的查询:

item 字段,item 和 location 字段,item 和location和 stock 字段.

MongoDB还可以使用索引来支持对item 和 stock字段的查询,因为item字段属于前缀。但是,该索引在支持查询方面不如仅基于item和stock的索引有效。

但是,MongoDB无法使用复合索引来支持包含以下字段的查询,因为如果没有item字段,则列出的任何字段都不对应于前缀索引:

location 字段,stock 字段,或location 和stock 字段。

如果您的集合同时具有复合索引和前缀索引(例如{ a: 1, b: 1 } 和{ a: 1 }),如果两个索引都不具有稀疏约束或唯一约束,则可以删除前缀上的索引(例如{ a: 1 })。 MongoDB在所有使用前缀索引的情况下都将使用复合索引。

四、索引交集

从2.6版开始,MongoDB可以使用索引交集来完成查询。 创建支持查询的复合索引还是依赖索引交集之间的选择取决于系统的具体情况。 有关更多详细信息,请参见索引交集和复合索引。

 

五、其他注意事项

参考上篇《单字段索引》的【五、其他注意事项】。

上一篇:单字段索引

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。