版本: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的更多相关文章

  1. MongoDB学习笔记二- Mongoose

    MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ...

  2. NumPy学习笔记 二

    NumPy学习笔记 二 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...

  3. Elasticsearch笔记二之Curl工具基本操作

    Elasticsearch笔记二之Curl工具基本操作 简介: Curl工具是一种可以在命令行访问url的工具,支持get和post请求方式.-X指定http请求的方法,-d指定要传输的数据. 创建索 ...

  4. Redis学习笔记二 (BitMap算法分析与BitCount语法)

    Redis学习笔记二 一.BitMap是什么 就是通过一个bit位来表示某个元素对应的值或者状态,其中的key就是对应元素本身.我们知道8个bit可以组成一个Byte,所以bitmap本身会极大的节省 ...

  5. Django学习笔记二

    Django学习笔记二 模型类,字段,选项,查询,关联,聚合函数,管理器, 一 字段属性和选项 1.1 模型类属性命名限制 1)不能是python的保留关键字. 2)不允许使用连续的下划线,这是由dj ...

  6. Django开发笔记二

    Django开发笔记一 Django开发笔记二 Django开发笔记三 Django开发笔记四 Django开发笔记五 Django开发笔记六 1.xadmin添加主题.修改标题页脚和收起左侧菜单 # ...

  7. 学习笔记(二)--->《Java 8编程官方参考教程(第9版).pdf》:第七章到九章学习笔记

    注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法者自负一切 ...

  8. muduo学习笔记(二)Reactor关键结构

    目录 muduo学习笔记(二)Reactor关键结构 Reactor简述 什么是Reactor Reactor模型的优缺点 poll简述 poll使用样例 muduo Reactor关键结构 Chan ...

  9. python3.4学习笔记(二十二) python 在字符串里面插入指定分割符,将list中的字符转为数字

    python3.4学习笔记(二十二) python 在字符串里面插入指定分割符,将list中的字符转为数字在字符串里面插入指定分割符的方法,先把字符串变成list然后用join方法变成字符串str=' ...

  10. webpack笔记二 管理资源

    webpack笔记二 管理资源 webpack最出色的功能之一就是除了引入JavaScript,还可以通过loader引入任何其它类型的文件. 加载CSS 为了在JavaScript模块中import ...

随机推荐

  1. 在Sql Server中使用证书加密数据

    IF NOT EXISTS () CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'QWE23987zxJKL569&agf1$94467GRkjg5k3 ...

  2. create-trigger-insert-pwd

    delimiter | drop trigger if exists default_insert_Pwd; create trigger default_insert_Pwd before inse ...

  3. 码云平台, 生成并部署SSH key

    参考链接: http://git.mydoc.io/?t=154712 步骤如下: 1. 生成 sshkey: ssh-keygen -t rsa -C "xxxxx@xxxxx.com&q ...

  4. Python菜鸟之路:Django 信号

    Django中提供了“信号调度”,用于在框架执行操作时解耦.通俗来讲,就是一些动作发生的时候,信号允许特定的发送者去提醒一些接受者. 相当于我们创建了一个hook. 1. Django的内置信号 Mo ...

  5. Java基础语法 - 面向对象 - static 关键字

    使用static关键字修饰的变量.常量和方法分别被称作静态变量.静态常量和静态方法,也被称作类的静态成员 静态变量 使用static修饰过的类变量称为静态变量 该变量需要使用类名.变量名进行调用,不能 ...

  6. android studio上传项目到github报错Successfully created project 'Demo' on GitHub, but initial commit failed:

    今天博主正在愉快地学习在AndroidStudio中使用Git,结果报了下面这个错∑(っ°Д°;)っ: Can't finish GitHub sharing process Successfully ...

  7. android学习五---OpenCV for android环境搭建

    学习android的目的是想在手机上实现计算机视觉的算法.一般算法的研究都是在Matlab上进行,但是手机平台没有那么多的计算资源,用matlab显然是不太现实的.而OpenCV是基于C++语言编写的 ...

  8. sql查询原理和Select执行顺序

    一 sql语句的执行步骤 1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义. 2) 语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限. 3)视图转换,将涉及视图的 ...

  9. 使用ansible 完成yum安装lamp环境

    使用ansible 完成yum安装lamp环境 [root@node2 ~]# cd /etc/ansible/playbook/[root@node2 playbook]# lslamp[root@ ...

  10. python全栈开发从入门到放弃之字符编码

    一 了解字符编码的知识储备   1. 计算机基础知识(三幅图)       2. 文本编辑器存取文件的原理(nodepad++,pycharm,word) 打开编辑器就打开了启动了一个进程,是在内存中 ...