MongoDB(八):索引[通俗易懂]

MongoDB(八):索引[通俗易懂]1. 索引 索引支持查询的有效地提高效率。没有索引,MongoDB必须扫描集合的每个文档,以选择与查询语句匹配的文档。这种扫描效率很低,需要MongoDB处理大量的数据。 索引是特殊的数据结构,以易于

1. 索引

索引支持查询的有效地提高效率。没有索引,MongoDB必须扫描集合的每个文档,以选择与查询语句匹配的文档。这种扫描效率很低,需要MongoDB处理大量的数据。

索引是特殊的数据结构,以易于遍历的形式存储数据集的一小部分。 索引存储特定字段或一组字段的值,按照索引中指定的字段值排序。

1.1 索引案例

首先创建大量数据。

向集合中插入10万条文档。

for(i=0;i<100000;i++){
db.t1.insert({name:"test"+i, age:i})
}

代码100分

然后进行数据查找性能分析。

查找姓名为”test10000″的文档。

代码100分db.t1.find({name:"test10000"})

使用explain()命令进行查询性能分析。

db.t1.find({name:"test10000"}).explain("executionStats")

其中的executionStats下的executionTimeMillis表示整体查询时间,单位是毫秒。

性能分析结果如下:

MongoDB(八):索引[通俗易懂]

 

然后我们创建索引。

1表示升序,-1表示降序。 

代码100分db.集合.ensureIndex({属性:1})
如
db.t1.ensureIndex({name:1})

执行上面相同的查询,并进行查询性能分析。

db.t1.find({name:"test10000"}).explain("executionStats")

性能分析结果如下:

MongoDB(八):索引[通俗易懂]

 

1.2 ensureIndex()方法

创建索引,需要使用MongoDB的ensureIndex()方法。

语法:

db.COLLECTION_NAME.ensureIndex({KEY:1})

这里的key是要在其上创建索引的字段的名称。

ensureIndex()方法也接受选项列表(可选)。

以下是列表:

参数  

类型

描述

background

Boolean

在后台构建索引,以便构建索引不会阻止其他数据库活动,则指定background的值为true。默认值为false

unique

Boolean

创建一个唯一的索引,使得集合不会接受索引键或键匹配索引中现有值的文档的插入。 指定true以创建唯一索引。 默认值为false

name

String

索引的名称。如果未指定,则MongoDB通过连接索引字段的名称和排序顺序来生成索引名称。

dropDups

Boolean

在可能有重复项的字段上创建唯一索引。MongoDB仅索引第一次出现的键,并从集合中删除包含该键的后续出现的所有文档。指定true以创建唯一索引。 默认值为false

sparse

Boolean

如果为true,则索引仅引用具有指定字段的文档。这些索引在某些情况下(特别是排序)使用的空间较小,但行为不同。默认值为false

expireAfterSeconds

integer

指定一个值(以秒为单位)作为TTL,以控制MongoDB在此集合中保留文档的时间。

v

索引版本

索引版本号。默认索引版本取决于创建索引时运行的MongoDB的版本。

weights

文档

权重是从199999之间的数字,并且表示该字段相对于其他索引字段在分数方面的意义。

default_language

String

对于文本索引,确定停止词列表的语言以及句柄和分词器的规则。 默认值为英文。

language_override

String

对于文本索引,要指定文档中包含覆盖默认语言的字段名称。默认值为language

1.3 索引的命令

建立唯一所有,实现唯一约束的功能。

db.t1.ensureIndex({"name":1},{"unique":true})

联合所有,对多个属性建立一个索引,按照find()出现的顺序。

db.t1.ensureIndex({name:1,age:1})

查看文档所有索引。

db.t1.getIndexes()

查看集合索引大小。

db.t1.totalIndexSize()

删除索引。

db.ti.dropIndexes("索引名称")

删除集合所有索引。

db.t1.dropIndexes()

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10401.html

(0)
上一篇 2022-12-28
下一篇 2022-12-28

相关推荐

  • metadata怎么打开_查看过分享是什么意思

    metadata怎么打开_查看过分享是什么意思作者:洪斌 爱可生南区负责人兼技术服务总监,MySQL ACE,擅长数据库架构规划、故障诊断、性能优化分析,实践经验丰富,帮助各行业客户解决 MySQL 技术问题,为金融、运营商、互联网等行业客户提…

    2023-03-13
    161
  • Redis入门(4) – 排序[亲测有效]

    Redis入门(4) – 排序[亲测有效]SORT命令 LIMIT参数 BY参数 GET参数 STORE参数 排序性能优化 很多场合需要对元素进行排序,这时除了使用有序集合外,还可以借助Redis提供的SORT命令来排序。 SORT命令 SO

    2023-03-06
    152
  • Python计数循环:让代码重复执行指定次数

    Python计数循环:让代码重复执行指定次数在编写程序时,我们经常需要通过循环来执行重复的操作,而计数循环(counting loop)是Python中最基本也最常用的循环类型之一。计数循环经常被用来处理重复次数已知的操作,以下是使用Python计数循环的详细介绍。

    2024-01-25
    106
  • Python截取字符串

    Python截取字符串在编程中,字符串是最基础的数据类型之一。字符串是由几个字符组成的有序序列,可以包含任何字符,包括字母、数字和符号等。在Python中,字符串是不可变的,即一旦创建就不能被修改。

    2024-06-16
    52
  • 解决Python unboundlocalerror异常的有效方法

    解决Python unboundlocalerror异常的有效方法在Python中,当一个函数中尝试使用未被定义的本地变量时,就会出现unboundlocalerror异常。这个异常通常会出现在嵌套的函数中,而且通常只会在Python 3以后的版本中才会发生,因为Python 2中的变量作用域规则不同。

    2024-04-07
    82
  • 利用Python实现有效的数字判断

    利用Python实现有效的数字判断在Python中,数字是一种基本数据类型,包括整型(int)、浮点型(float)、复数(complex)和布尔型(bool)。

    2024-02-09
    89
  • 以Python设置x轴刻度为中心的方法

    以Python设置x轴刻度为中心的方法在处理数据可视化时,经常会遇到需要设置图表的x轴刻度为中心的情况。例如,展示某个时间范围内的数据,希望让图表的中心刻度点对应的时间为某个特定的时间点。本文将介绍如何使用Python来实现这个功能。

    2024-05-02
    83
  • 关于Aborted connection告警日志的分析[亲测有效]

    关于Aborted connection告警日志的分析[亲测有效]前言: 有时候,连接MySQL的会话经常会异常退出,错误日志里会看到"_Got an error reading communication packets_"类型的告警。本篇文章

    2023-02-08
    149

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注