覆盖查询是一种可以完全使用索引来满足的查询,而不必检索任何文档。当同时满足以下两个条件时,索引将涵盖查询。
- 所有查询的字段是索引的一部分;
- 所有返回的字段位于同一索引中。
{
"_id": ObjectId("5bbda40614649ff872c72f39"),
"contact": "13800138000",
"dob": "1991-11-11",
"gender": "M",
"name": "benben",
"user_name": "benben_2015"
}
例如给上面的test
集合添加联合索引,字段为gender
和user_name
。
>db.test.createIndex({gender:1,user_name:1})
下面通过几个例子来依次讲解满足的两个条件。
1.当使用db.test.find({contact:"13800138000",gender:"M"},{dob:1})
时,mongodb会查询数据块文档。返回的结果如下图所示:
这是因为查询的字段contact
不是索引的一部分。
2.当使用db.test.find({user_name:"benben_2015",gender:"M"},{dob:1})
时,mongodb依旧会查询数据库文档,返回的结果如下图所示:
这是因为不满足第二个条件。由于除了_id
字段,查询中存在的所有字段都是索引的一部分。而在默认情况下,查询时_id
字段是返回的,这就导致返回的字段dob
和_id
没有位于同一索引中。
3.当使用db.test.find({user_name:"benben_2015",gender:"M"},{dob:1,_id:0})
时,mongodb不会查找数据库文档,相反,它将从索引数据中获取所需的数据。这是非常快速的数据查询,返回结果如下图所示:
因此,当我们使用索引查询某个文档除_id字段的内容时,可以使用命令这样的命令:db.collection.find({index1:"value1",...},{_id:0})
,例如:db.test.find({user_name:"benben_2015",gender:"M"},{_id:0})
。返回的结果如下图所示:
参考文章: