索引是一种特殊的数据结构,存储设置在一个易于遍历形式的数据的一小部分。索引存储一个特定的字段或一组字段的值,在索引中指定的值的字段排列的,对mongoDB索引相关知识感兴趣的朋友跟随小编一起学习下吧
MongoDB 索引
索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录。
这种扫描全集合的查询效率是非常低的,特别在处理大量的数据时,查询可以要花费几十秒甚至几分钟,这对网站的性能是非常致命的。
索引是特殊的数据结构,索引存储在一个易于遍历读取的数据集合中,索引是对数据库表中一列或多列的值进行排序的一种结构。
mongo可以通过创建索引来提高查询的速度。
1. 开始与准备数据
启动mongo并选择目标数据库
mongo
use test
然后准备一组数据(10万条数据,较大的数据量)
for(i=0;i<100000;i++){db.test.insert({name:'test'+i,age:i})}
2. 创建索引前
查询一下name为"test90000"的数据。并使用explain方法来查看查询的性能。
db.test1.find({name:"test90000"}).explain('executionStats')
这里可以看到查询花了53毫秒
3. 创建索引 createIndex
给字段name创建索引
db.test1.createIndex({name: 1})
查看索引:
给name创建索引之前,_id字段默认为索引,创建后集合有两个索引,"_id"和"name"。
4. 创建索引后
再次查找该条数据,并查看查询的性能,发现所用时间接近0毫秒。即设定索引后查询性能大大提升了。
db.test1.find({name:"test90000"}).explain('executionStats')
5. 删除索引
db.test1.dropIndex({name:1})
查看之
db.test1.getIndexes()
如图,只剩下了"_id"一个索引。"name"索引已被删除。
6.唯一索引与符合索引
①唯一索引
db.test1.createIndex({name: 1},{"unique":true})
查看索引
db.test1.getIndexes()
可以看到,unique为true。
设定为唯一索引后,该索引的值不能重复。
(这个特点也可以用于写爬虫时不想要某字段的重复数据时,达到去重的目的。)
如图插入一条name重复的数据时,会产生如下报错:
即插入失败了。
②复合索引
创建多个索引的方式被称为复合索引。
首先删掉刚刚创建的索引name
db.test1.dropIndex({name:1})
然后一次创建name,age两个索引
db.test1.createIndex({'name':1,'age':1})
处理海量数据时,在一定的规则下使用复合索引,可以大幅提升查询的性能.
到此这篇关于mongoDB数据库索引快速入门指南的文章就介绍到这了,更多相关mongoDB索引内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:mongoDB数据库索引快速入门指南
- Numpy中如何创建矩阵并等间隔抽取数据 2023-07-28
- 搭建单机Redis缓存服务的实现 2023-07-13
- Oracle 删除大量表记录操作分析总结 2023-07-23
- 在阿里云CentOS 6.8上安装Redis 2023-09-12
- redis清除数据 2023-09-13
- SQLSERVER调用C#的代码实现 2023-07-29
- 基于Python制作一个简单的文章搜索工具 2023-07-28
- Mongodb启动报错完美解决方案:about to fork child process,waiting until server is ready for connections. 2023-07-16
- SQL Server 2022 AlwaysOn新特性之包含可用性组详解 2023-07-29
- MySQL8.0.28安装教程详细图解(windows 64位) 2023-07-26