mongoDB 简单的索引类型

举报
liuzhen007 发表于 2021/11/14 23:21:12 2021/11/14
【摘要】 ​ 目录前言正文一、索引的工作原理二、单一索引三、复合索引结尾前言我们都知道,在关系型数据库中,索引对于优化数据库的查询操作非常重要。那么,我们不禁要问:什么是索引呢?其实,索引就是一个排序的列表,在这个列表中存储着索引的值和包含这个值的数据对应的物理地址。索引的优势就是大大加快查询速度。所以,我们的任务就是探索 mongoDB 中简单的索引类型。正文一、索引的工作原理索引的本质就是一个排序...

 目录

前言

正文

一、索引的工作原理

二、单一索引

三、复合索引

结尾


前言

我们都知道,在关系型数据库中,索引对于优化数据库的查询操作非常重要。那么,我们不禁要问:什么是索引呢?其实,索引就是一个排序的列表,在这个列表中存储着索引的值和包含这个值的数据对应的物理地址。索引的优势就是大大加快查询速度。所以,我们的任务就是探索 mongoDB 中简单的索引类型。

正文

一、索引的工作原理

索引的本质就是一个排序的列表,其中记录了索引的值和包含这个值的数据对应的物理地址,因此,我们在查询数据库的时候,可以不需要全表扫描来定位某行的数据,而是通过索引找到对应的物理地址,再通过物理地址来访问对应的数据。

索引的优势是加快了数据的检索、排序、分组的速度,减少磁盘I/O,但是索引也有缺点,并不是越多越好,因为索引本身也是数据表,需要占用存储空间。另外,索引的变化也需要对数据库进行维护,比如对索引列的值进行增改删操作时,数据库也需要更新索引表,这会增加数据库的压力。

二、单一索引

单一索引就是单个字段的索引列,其实,在 mongoDB 数据库中,所有的表都是默认单一索引的,只是索引的字段是 _id。

我们在设置单一索引时,需要把经常访问,就是经常作为过滤条件的字段设置为索引,比如,在数据库表中,我们非常关心最近的一些数据,那么可以给时间戳字段增加一个索引,命令如下:

db.files.createIndex({timestamp:-1})

其中,-1 表示降序,1 表示生序。

三、复合索引

复合索引就是一个索引包括多个字段,用法是基本一致的。比如,除了上面提到时间戳,再增加一个文件大小,具体命令如下:

db.files.createIndex({"size":1,"timestamp":-1})

上面命令的意思就是数据库表首先按照 size 大小升序排序,当存在相同大小的文件时,再按照时间戳倒序排列。

结尾

好了,今天关于 mongoDB 数据库中的两种简单索引类型就介绍完了,感兴趣的话,就请自己动手吧!



作者简介:大家好,我是 liuzhen007(Data-Mining),是一位音视频技术爱好者,同时也是CSDN博客专家、华为云社区云享专家、签约作者,欢迎关注我分享更多干货!

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。