为编程爱好者分享易语言教程源码的资源网
好用的代理IP,游戏必备 ____广告位招租____ 服务器99/年 ____广告位招租____ ____广告位招租____ 挂机,建站服务器
好用的代理IP,游戏必备 ____广告位招租____ 服务器低至38/年 ____广告位招租____ ____广告位招租____ 挂机,建站服务器

网站首页 > 数据库 > MongoDB 正文

MongoDB基础--覆盖索引查询(mongodb基础查询语句)

三叶资源网 2022-06-26 08:09:21 MongoDB 434 ℃ 0 评论

覆盖索引查询

覆盖查询是以下的查询:
* 所有的查询字段是索引的一部分
* 所有的查询返回字段在同一个索引中
  
  由于所有出现在查询中的字段是索引的一部分, MongoDB 无需在整个数据文档中检索匹配查询条件和返回使用相同索引的查询结果。因为索引存在于RAM中,从索引中获取数据比通过扫描文档读取数据要快得多。
  例:user集合:

{
   "_id": ObjectId("53402597d852426020000002"),
   "contact": "987654321",
   "dob": "01-01-1991",
   "gender": "M",
   "name": "Tom Benzamin",
   "user_name": "tombenzamin"
}

  创建联合索引,字段为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})
  如果所有索引字段是一个数组则不能使用覆盖索引查询
  1 所有索引字段是一个子文档
  2 所有索引字段是一个数组



mongoDB基础系列,会持续更新,想了解的朋友可以关注 ,文章有帮助的话可以长按点赞有惊喜!!!文章比较长,大家可以先 收藏转发后再看有什么补充可以在下面评论,谢谢大家

Tags:

来源:三叶资源网,欢迎分享,公众号:iisanye,(三叶资源网⑤群:21414575

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

百度站内搜索
关注微信公众号
三叶资源网⑤群:三叶资源网⑤群

网站分类
随机tag
淘口令解析算法模块源码卡盟管理系统行内元素APlayer模块源码WEB交互折线图编码转换拼多多滑块验证终极版哈希表sqlite淘宝宝贝列表分页源码接口彗星HTTP支持库登陆查询取色器界面设计群空间易语言IDE界面调试
最新评论