覆盖查询是:所有的查询字段是索引的一部分、所有的查询返回字段在同一个索引中
因为所有出现在查询中的字段是索引的一部分, MongoDB 无需在整个数据文档中检索匹配查询条件和返回使用相同索引的查询结果
因为索引存在于 RAM 中,从索引中获取数据比通过扫描文档读取数据要快得多
使用覆盖索引查询
为了测试盖索引查询,假设我们有以下 users 集合
{
"_id" : ObjectId("59ee8a8ba0f7c7d445f864af"),
"tel" : "13888886666",
"birthday" : "11-11",
"sex" : "M",
"name" : "Ro dabaicai",
"user_name" : "dabaicai"
}
我们在 users 集合中创建联合索引,字段为 sex 和 user_name
> db.users.ensureIndex({sex:1,user_name:1})
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
现在,该索引会覆盖以下查询
> db.users.find({sex:"M"},{user_name:1,_id:0})
{ "user_name" : "dabaicai" }
也就是说,对于上述查询,MongoDB 不会去数据库文件中查找
相反,它会从索引中提取数据,这是非常快速的数据查询
由于我们的索引中不包括 _id 字段,_id在查询中会默认返回,我们可以在 MongoDB 的查询结果集中排除它
下面的范例没有排除_id,查询就不会被覆盖:
>db.users.find({sex:"M"},{user_name:1})
最后,如果是以下的查询,不能使用覆盖索引查询:
- 所有索引字段是一个数组
- 所有索引字段是一个子文档
最新评论
徒弟可以A师傅,学生可以A老师,为什么外包不能A正式,我觉得很正常。异性相吸这是宇宙真理
PHP天下第一(狗头叼花)
第一个不需要关注公主号直接给激活码的帖子!
客户端超时断开后,服务端如果没有设置超时机制,那也会继续等待处理,万一这期间有消息到了,那不是就接受到消息处理了,但是也没有办法返回到客户端,导致消息丢失。
企业级GO项目开发实战 Kubernetes权威指南 第六版
https://pan.baidu.com/s/1q3bnTncIACKoTZFxvx7BQw?pwd=ii7n
RabbitMQ精讲,项目驱动落地,分布式事务拔高 有吗?
Spring Cloud Alibaba 微服务架构实战 https://pan.baidu.com/s/1jF5voFRoeF0lYAzAPBWSbw?pwd=chqk