写点什么

开心档 - 软件开发入门之 MongoDB 覆盖索引查询

作者:雪奈椰子
  • 2023-02-07
    广东
  • 本文字数:762 字

    阅读完需:约 3 分钟

开心档-软件开发入门之MongoDB 覆盖索引查询

   


前言

本章将会讲解MongoDB 覆盖索引查询

目录

MongoDB 覆盖索引查询

使用覆盖索引查询



官方的 MongoDB 的文档中说明,覆盖查询是以下的查询:

  • 所有的查询字段是索引的一部分

  • 所有的查询返回字段在同一个索引中

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

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


使用覆盖索引查询

为了测试覆盖索引查询,使用以下 users 集合:


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


我们在 users 集合中创建联合索引,字段为 gender 和 user_name :


>db.users.createIndex({gender:1,user_name:1})
复制代码


**注:**5.0 之前版本可以使用 db.collection.ensureIndex() ,但 ensureIndex() 在 5.0 版本后已被移除,使用 createIndex() 代替。

现在,该索引会覆盖以下查询:


>db.users.find({gender:"M"},{user_name:1,_id:0})
复制代码


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

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

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


>db.users.find({gender:"M"},{user_name:1})
复制代码


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

  • 所有索引字段是一个数组 所有索引字段是一个子文档

 上一篇

MongoDB - 连接

下一篇 

MongoDB 创建集合

用户头像

雪奈椰子

关注

还未添加个人签名 2022-07-22 加入

还未添加个人简介

评论

发布
暂无评论
开心档-软件开发入门之MongoDB 覆盖索引查询_mongodb_雪奈椰子_InfoQ写作社区