开发者社区> ArimaMisaki> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

一幅长文细学MongoDB(四)——索引

简介: 本文主要讲述了MongoDB的索引机制以及如何操作索引
+关注继续查看

4 索引

4.1 概述

说明:索引支持在MongoDB中高效地查询。如果没有索引,MongoDB必须执行全集合扫描,即扫描集合中的每个文档,以选择与查询语句匹配的文档。这种扫描全集合的查询效率是非常低的,特别是处理大量的数据时,查询可以花费几十秒甚至几分钟,这对网站的性能是十分致命的。

适当地建立索引可以提升扫描的效率。MongoDB采用的索引为B树索引。


4.2 索引类型

单字段索引:MongoDB支持在文档的单个字段上创建用户定义的升序/降序索引,称为单字段索引(Single Field Index)

复合索引

地理空间索引


4.3 索引创建

创建索引

db.集合名.createIndex({KEY:1},参数);
或
db.集合名.ensureIndex({KEY:1},参数);

其中参数选项为:

ParameterTypeDescription
backgroundBoolean建索引过程会阻塞其它数据库操作,background可指定以后台方式创建索引,即增加 "background" 可选参数。 "background" 默认值为false
uniqueBoolean建立的索引是否唯一。指定为true创建唯一索引。默认值为false.
namestring索引的名称。如果未指定,MongoDB的通过连接索引的字段名和排序顺序生成一个索引名称。
dropDupsBoolean在建立唯一索引时是否删除重复记录,指定 true 创建唯一索引。默认值为 false.
sparseBoolean对文档中不存在的字段数据不启用索引;这个参数需要特别注意,如果设置为true的话,在索引字段中不会查询出不包含对应字段的文档.。默认值为 false.
expireAfterSecondsinteger指定一个以秒为单位的数值,完成 TTL设定,设定集合的生存时间。
vindex version索引的版本号。默认的索引版本取决于mongod创建索引时运行的版本。
weightsdocument索引权重值,数值在 1 到 99,999 之间,表示该索引相对于其他索引字段的得分权重。
default_languagestring对于文本索引,该参数决定了停用词及词干和词器的规则的列表。 默认为英语
language_overridestring对于文本索引,该参数指定了包含在文档中的字段名,语言覆盖默认的language,默认值为 language.

查看索引

db.集合名.find().pretty();

image-20220920182111389


4.3 删除索引

索引删除

db.集合名.dropIndex(索引名称)

image-20220920182805085


4.4 查看索引执行计划

执行计划:一个索引建立在字段上后是否被使用我们是不知道的,此时通过下面的命令可以查看在查询过程中是否使用了索引进行查询,通过winningPlan的stage查看其扫描使用的方式。

db.集合名.find(条件).explain(参数)


4.5 涵盖的查询

说明:当查询条件和查询的投影仅包括索引的字段时,MongoDB直接从索引返回结果,而无需扫描任何文档或将文档带入内存;这种查询的方式显得十分高效。


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MongoDB的索引和查询分析(explain)
MongoDB的索引和查询分析(explain)
1100 0
MongoDB 4.2新特性:分布式事务、字段级加密、通配符索引、物化视图
MongoDB 4.2已经发布,我们来看看它增加了哪些新特性?分布式事务?数据库加密?通配符索引?
2330 0
MongoDB索引介绍
一、Single Field Indexes 示例文档: { "_id": ObjectId("570c04a4ad233577f97dc459"), "score": 1034, "location": { state: "NY", city: "New York" } } 1、语法: db.
847 0
MongoDB · 引擎特性 · MongoDB索引原理
为什么需要索引? 当你抱怨MongoDB集合查询效率低的时候,可能你就需要考虑使用索引了,为了方便后续介绍,先科普下MongoDB里的索引机制(同样适用于其他的数据库比如mysql)。 mongo-9552:PRIMARY> db.
1207 0
MongoDB 稀疏(间隙)索引(Sparse Indexes)
稀疏索引(或者称间隙索引)就是只包含有索引字段的文档的条目,即使索引字段包含一个空值。也就是说间隙索引可以跳过那些索引键不存在的文档。
1371 0
MongoDB 部分索引(Partial Indexes)
MongoDB部分索引只为那些在一个集合中,满足指定的筛选条件的文档创建索引。由于部分索引是一个集合文档的一个子集,因此部分索引具有较低的存储需求,并降低了索引创建和维护的性能成本。
1484 0
+关注
ArimaMisaki
一个认真并且每天保持学习的开荒者
文章
问答
文章排行榜
最热
最新
相关电子书
更多
PostgresChina2018_张启程_为什么我们抛弃MongoDB和MySQL,选择PgSQL
立即下载
开源数据库 MongoDB 专场 MongoDB疑难杂症分析及优化
立即下载
阿里技术专家一挃:MongoDB 优化器 & 执行器介绍
立即下载