Mongodb笔记(二) Index
版本:mongodb3.4;
Index :
如果mongodb不能使用索引进行排序,就会将数据放入内存中进行排序,而当内存使用超过32MB时,就会报错。
在创建索引时,应确保索引的选择力,避免多余的查询。避免没有选择力的索引。
_id是默认的索引。
基本方法:
db.collection.createIndex({A:1});
db.collection.dropIndex({A:1}); //两种方法删除。
.dropIndex('indexName');
db.collection.dropIndexes();
db.collection.getIndexes();
db.collection.reIndex(); //重建index
一,Single Indexes单项索引:
{field:1}
二,Compound Indexes复合索引:
{A:1,B:1}
两个field都建立索引。
查询: find ( { A: value}) //使用index;
find( { A:value, B:value}) //使用Index;
find ( { }) .sort({B:1}) // nonuse; 复合索引单独使用一个时,只认第一个(A)。此处使用索引交集,可以成功。
find( { } ).sort ({A:1}) //use
.sort({A:1}) // use;
.sort ({ A:1,B:1}) //use;
.sort ( {A:-1,B:-1}) //use;
.sort({A:-1,B:1}) // nonuse;
三,Multikey Indexes多键索引:
1。:
document: {A: [ 1,2,3] }
index: {A:1}
find ({A:1}) //如此使用该索引;
2。复合索引:
复合索引中只能出现一个多键索引,所以:
index:{A:1,B:1}
insert({ A:[1,2],B:[1,2]}) //error;
insert( {A:[1,2] ,B: 1}) //pass;
3.the array Field contain nested Objects:
document: {A: [ { a:1, b:2}, { a: 3, b: 4}]},
index{ A.a : 1} 通过这样,对其建立索引;
四,Text Index文本索引:
通过正则来匹配文档,是很耗性能的。所以有这么一个text Index;
使用: createIndex({A:'text'}) , 默认是使用英语。
可以通过第二个属性来定义语言: createIndex({A:'text'}, { default_language:'hans'});
hans是简体中文。可惜mongod企业版中才能使用中文的Text Index。
五,Index Intersection索引交集:
比如你有如下索引:
index:{A:1},
index:{B: 1,C:1},
index { B:1}
find ( { A:value , B :value } ) //支持
find ( { A:value } ) .sort ( { B: 1}) //不支持
find ( { B:value} ) .sort ( { C:1}) //支持,使用了 {B:1,C:1}这个索引,虽然有{B:1}这个single Index;
六,Index properties索引属性:
1,TTL(设置document过期时间):
db.test.createIndex( {expire:1} , { expireAfterSeconds:3000} );
建议一个expire的索引,其在document中所接受的值必须为:BSON日期类型。或者Array<BSON>;
插入的document将在其指定的时间+3000S后被删除。
也就是插入时,就得到了这个过期时间。mongodb周期性地,将这个过期时间与目前时间比较,小于等于目前时间时,该数据过期。比如:
db.test.insert ({ expire : new Date()}); 就会在3000S后过期。
接下面的例子:
var time= new Date();
time.setFullYear(time.getFullYear()-1); db.test.update({....},{expire:time}); //将时间改为更早,使得document提前过期;
db.test.update({....},{$currentDate:{expire:true}}) //将时间修正为当前,强行续命!
mongdb里的expire 与Redis中是不一样的。需要多理解。
2,Unique唯一索引:
create( { id:1} , {unique:ture} )
在collection中每个document的id都是唯一,重复者不能写入。
3,Partical局部索引:
create({ name:1}, { age:{$gt:20}});
只对age大于20的document进行索引。与unique连用时,不被索引区不受unique限制。
4,Sparse稀疏索引:
create({name:1},{sparse:true});
不使用时,当有一个及以上document没有name属性时,db.test.distinct('name') 将会返回一个null。因为查询时,遍历了这些文档。
使用稀疏,db.test.distinct('name')。不会查询没有name属性的document。返回应得值。
db.find({}).sort({name:1}) //默认不会使用稀疏索引。所以这里改用强制指定索引:
db.find({}).sort({name:1}).hint({name:1}) //强行使用name Index;
db.find({}).hint({$natural:1}) //禁用一切索引进行查询
在replSet上创建索引:
https://docs.mongodb.com/manual/tutorial/build-indexes-on-replica-sets/
Mongodb笔记(二) Index的更多相关文章
- MongoDB学习笔记二- Mongoose
MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ...
- NumPy学习笔记 二
NumPy学习笔记 二 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...
- Elasticsearch笔记二之Curl工具基本操作
Elasticsearch笔记二之Curl工具基本操作 简介: Curl工具是一种可以在命令行访问url的工具,支持get和post请求方式.-X指定http请求的方法,-d指定要传输的数据. 创建索 ...
- Redis学习笔记二 (BitMap算法分析与BitCount语法)
Redis学习笔记二 一.BitMap是什么 就是通过一个bit位来表示某个元素对应的值或者状态,其中的key就是对应元素本身.我们知道8个bit可以组成一个Byte,所以bitmap本身会极大的节省 ...
- Django学习笔记二
Django学习笔记二 模型类,字段,选项,查询,关联,聚合函数,管理器, 一 字段属性和选项 1.1 模型类属性命名限制 1)不能是python的保留关键字. 2)不允许使用连续的下划线,这是由dj ...
- Django开发笔记二
Django开发笔记一 Django开发笔记二 Django开发笔记三 Django开发笔记四 Django开发笔记五 Django开发笔记六 1.xadmin添加主题.修改标题页脚和收起左侧菜单 # ...
- 学习笔记(二)--->《Java 8编程官方参考教程(第9版).pdf》:第七章到九章学习笔记
注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法者自负一切 ...
- muduo学习笔记(二)Reactor关键结构
目录 muduo学习笔记(二)Reactor关键结构 Reactor简述 什么是Reactor Reactor模型的优缺点 poll简述 poll使用样例 muduo Reactor关键结构 Chan ...
- python3.4学习笔记(二十二) python 在字符串里面插入指定分割符,将list中的字符转为数字
python3.4学习笔记(二十二) python 在字符串里面插入指定分割符,将list中的字符转为数字在字符串里面插入指定分割符的方法,先把字符串变成list然后用join方法变成字符串str=' ...
- webpack笔记二 管理资源
webpack笔记二 管理资源 webpack最出色的功能之一就是除了引入JavaScript,还可以通过loader引入任何其它类型的文件. 加载CSS 为了在JavaScript模块中import ...
随机推荐
- Eclipse打包java工程
Eclipse打包java工程步骤如下: 1.选择预打包的工程->Export. 2.选择java->JAR file. 3.导出JAR文件设置. 这里有几个选项: Export gene ...
- 洛谷 P2073 送花
这题其实可以用vector水掉! 定义: 记住要用结构体(c为价格,x为美丽值)! 以c排序. struct Node { int x,c; bool operator < (const &am ...
- 3.Write Scripts for the mongo Shell-官方文档摘录
总结 1 使用js进行获取数据的方法 2 js方式和原生mongo shell的交互方式的区别写法 3 需要将所有数据打印出来使用到的循环示例 cursor = db.collection.find( ...
- 对比MySQL,你究竟在什么时候更需要MongoDB(转)
译文:对比MySQL,你究竟在什么时候更需要MongoDB 原文链接: When Should I Use MongoDB rather than MySQL (or other RDBMS): Th ...
- Java基础—数组(转载)
Java 语言中提供的数组是用来存储固定大小的同类型元素.其实数组就是一个容器. 创建数组 Java 中声明数组的语法有两种: dataType[] arrayRefVar; // 首选的方法 dat ...
- K NEAREST NEIGHBOR 算法(knn)
K Nearest Neighbor算法又叫KNN算法,这个算法是机器学习里面一个比较经典的算法, 总体来说KNN算法是相对比较容易理解的算法.其中的K表示最接近自己的K个数据样本.KNN算法和K-M ...
- Python(迭代、三元表达式、列表生成、生成器、迭代器)
迭代 什么是迭代 1 重复 2 下次重复一定是基于上一次的结果而来 如果给定一个list或tuple,我们可以通过for循环来遍历这个list或tuple,这种遍历我们称为迭代(Iteration). ...
- git---控制面板提交
比如我修改了一个项目的代码.需要提交代码. 1.打开项目所在目录,右键>Git Bash Here 2.打开交互模式.git会列出所有untracked的文件,然后你可以用各种形式加入.git ...
- SLF4J日志系统在项目导入时频现的问题
一.概述 近期在导入一个已有的项目时,日志系统出现了一个问题.错误信息如下: SLF4J问题 SLF4J: Failed to load class "org.slf4j.impl.Stat ...
- LightOJ - 1236 (唯一分解定理)
题意:求有多少对数对(i,j)满足lcm(i,j) = n,1<=i<=j, 1<=n<=1e14. 分析:根据整数的唯一分解定理,n可以分解为(p1^e1)*(p2^e2)* ...