
MongoDB 覆盖索引查询
发布日期:2021-05-07 21:02:58
浏览次数:20
分类:精选文章
本文共 791 字,大约阅读时间需要 2 分钟。
一、MongoDB 覆盖索引查询
官方的MongoDB的文档中说明,覆盖查询是以下的查询:
- 所有的查询字段是索引的一部分
- 所有的查询返回字段在同一个索引中
因为所有出现在查询中的字段是索引的一部分, MongoDB 无需在整个数据文档中检索匹配查询条件和返回使用相同索引的查询结果。
因为索引存在于RAM中,从索引中获取数据比通过扫描文档读取数据要快得多。
1.1 使用覆盖索引查询
为了测试覆盖索引查询,使用以下 users 集合:
{ "_id": ObjectId("53402597d852426020000002"), "contact": "987654321", "dob": "01-01-1991", "gender": "M", "name": "Tom Benzamin", "user_name": "tombenzamin"}
我们在 users 集合中创建联合索引,字段为 gender 和 user_name :
>db.users.ensureIndex({ gender:1,user_name:1})
现在,该索引会覆盖以下查询:
>db.users.find({ gender:"M"},{ user_name:1,_id:0})
也就是说,对于上述查询,MongoDB的不会去数据库文件中查找。相反,它会从索引中提取数据,这是非常快速的数据查询。
由于我们的索引中不包括 _id 字段,_id在查询中会默认返回,我们可以在MongoDB的查询结果集中排除它。下面的实例没有排除_id,查询就不会被覆盖:
>db.users.find({ gender:"M"},{ user_name:1})
最后,如果是以下的查询,不能使用覆盖索引查询:
- 所有索引字段是一个数组
所有索引字段是一个子文档
发表评论
最新留言
很好
[***.229.124.182]2025年04月07日 10时06分12秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
mui+vue.js实现上拉刷新和下拉加载
2021-05-08
mui返回到父页页面并进行刷新
2021-05-08
数据库中优化lock
2021-05-08
layui 点击选择框为啥会出现震动(已解决)
2021-05-08
地图划范围
2021-05-08
小程序滑块视图容器的使用
2021-05-08
考研数据结构LeetCode入门题
2021-05-08
(原创)在Linux上安装运行Python3(CentOS7为例)
2021-05-08
Linux RTC驱动分析及应用
2021-05-08
快速学习汇编之 通用寄存器
2021-05-08
快速学习汇编之 常见汇编指令
2021-05-08
变量覆盖漏洞
2021-05-08
java 之 集合篇
2021-05-08
weblogic之cve-2015-4852
2021-05-08
Java注释
2021-05-08
水调歌头·1024
2021-05-08
对不起
2021-05-08
C++ 函数默认参数
2021-05-08
C++ 函数重载
2021-05-08
matlab文件管理
2021-05-08