三十八、MongoDB 覆盖索引查询

覆盖查询是:所有的查询字段是索引的一部分、所有的查询返回字段在同一个索引中

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

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

使用覆盖索引查询

为了测试盖索引查询,假设我们有以下 users 集合

{
    "_id" : ObjectId("59ee8a8ba0f7c7d445f864af"),
    "tel" : "13888886666",
    "birthday" : "11-11",
    "sex" : "M",
    "name" : "Ro penglei",
    "user_name" : "penglei"
}

我们在 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" : "penglei" }

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

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

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

>db.users.find({sex:"M"},{user_name:1})

最后,如果是以下的查询,不能使用覆盖索引查询:

1、 所有索引字段是一个数组
2、 所有索引字段是一个子文档

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值