三十八、MongoDB 覆盖索引查询
创始人
2025-05-28 04:16:08
0

因为所有出现在查询中的字段是索引的一部分, 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、 所有索引字段是一个子文档

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...