MongoDB覆盖索引查询是什么,如何使用
Admin 2022-08-31 群英技术资讯 265 次浏览
官方的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})
最后,如果是以下的查询,不能使用覆盖索引查询:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
MongoDB 概念解析 不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是文档、集合、数据库,下面我们挨个介绍。 下表将帮助您更容易理解Mongo中的一些概念: SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table collection 数据库表/集合 row document 数据记录行/文档 column field 数..
mongodb数据库是可以做缓存的,MoongoDB特点是高性能、易部署、易使用,存储数据非常方便。MongoDB适用于单表数据操作、完整性要求不高的系统使用。
mongodb做主从的方法:1、首先启动主Mongodb实例;2、启动从Mongodb实例,用mongod --port 27018 --dbpath命令;3、验证主从模式。
mongodb中条件查询不等于用$ne,示例:db.things.find({x:{$ne:3}});为查询x的值不等于3的数据。其中things为查找的对象。
Mongodb中使用sort()方法对数据进行排序:1、用于对结果集进行排序,按照用户在输入参数中指定的升序或降序对文档进行排序。2、参数1为升序排列,参数-1为降序排列。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008