zoukankan      html  css  js  c++  java
  • 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.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})
    

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

      • 所有索引字段是一个数组
      • 所有索引字段是一个子文档
  • 相关阅读:
    下载linux历史版本
    CentOS7 常用命令集合
    oracle初级系列教程
    redis内存数据的持久化方式
    使用Spring 或Spring Boot实现读写分离( MySQL实现主从复制)
    三个线程ABC,交替打印ABC
    wait,notify,notifyAll详细介绍
    索引优化分析
    Git常用命令使用大全
    长连接 、短连接、心跳机制与断线重连(转载)
  • 原文地址:https://www.cnblogs.com/navysummer/p/8456589.html
Copyright © 2011-2022 走看看