举报投诉联系我们 手机版 热门标签 鳄鱼CMS
您的位置:鳄鱼CMS > mongodb 复合索引 MongoDB 覆盖索引查询

mongodb 复合索引 MongoDB 覆盖索引查询

2023-06-03 07:31 MongoDB教程

mongodb 复合索引 MongoDB 覆盖索引查询

mongodb 复合索引 MongoDB 覆盖索引查询

mongodb 复合索引

官方的 MongoDB 的文档中说明,覆盖查询是以下的查询:

  • 所有的查询字段是索引的一部分
  • 所有的查询返回字段在同一个索引中

由于所有出现在查询中的字段是索引的一部分, MongoDB 无需在整个数据文档中检索匹配查询条件和返回使用相同索引的查询结果。

因为索引存在于RAM中,从索引中获取数据比通过扫描文档读取数据要快得多。


为了测试盖索引查询,使用以下 mycol 集合:

{ "_id" : 1, "name" : "tom", "sex" : "男", "score" : 100, "age" : 34 }
{ "_id" : 2, "name" : "jeke", "sex" : "男", "score" : 90, "age" : 24 }
{ "_id" : 3, "name" : "kite", "sex" : "女", "score" : 40, "age" : 36 }
{ "_id" : 4, "name" : "herry", "sex" : "男", "score" : 90, "age" : 56 }
{ "_id" : 5, "name" : "marry", "sex" : "女", "score" : 70, "age" : 18 }
{ "_id" : 6, "name" : "john", "sex" : "男", "score" : 100, "age" : 31 }

我们在 mycol 集合中创建联合索引,字段为 sex 和 name :

db.mycol.ensureIndex({sex : 1, name : 1})

现在,该索引会覆盖以下查询:

db.mycol.find({sex: "男"},{name : 1, _id : 0})

 

也就是说,对于上述查询,MongoDB 的不会去数据库文件中查找。相反,它会从索引中提取数据,这是非常快速的数据查询。

由于我们的索引中不包括 _id 字段,_id 在查询中会默认返回,我们可以在 MongoDB 的查询结果集中排除它。

下面的实例没有排除 _id,查询就不会被覆盖:

db.mycol.find({sex: "男"},{name : 1})

 

最后,如果所有索引字段是一个数组,不能使用覆盖索引查询。


阅读全文
以上是鳄鱼CMS为你收集整理的mongodb 复合索引 MongoDB 覆盖索引查询全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 鳄鱼CMS eyucms.com 版权所有 联系我们