原文地址

一、介绍

我们已经很清楚索引会提高查询效率。如果没有索引,MongoDB必须对全部集合进行扫描,即,扫描集合中每条文档以选择那些符合查询条件的文档。对查询来说如果存在合适的索引,则MongoDB可以利用索引减少扫描的文档数。

索引是一种特殊的数据结构,其中存储了集合的数据集的一小部分,以便容易遍历。索引本质上存储的其实是单个字段或者字段组的值,并根据字段值进行排序。索引的排序支持有效的相等比较和基于范围的查询操作。另外,MongoDB通过索引中的排序返回存储的结果。

下图说明了一个查询并对匹配文档利用索引排序:

MongoDB的索引通常与其他数据库系统中的索引类似。MongoDB在集合这一层定义索引,并对一个集合中的任何字段或者文档的子字段支持索引操作。

注:MongoDB索引使用B树数据结构

索引类型

MongoDB提供一系列不同的索引类型以支持不同的数据和查询

默认 _id

所有的MongoDB集合有一个_id字段上的索引,这个索引是默认存在的。如果程序没有特别指定_id的值,那驱动程序或者Mongod将创建一个_id字段,其值为ObjectId。

_id索引是唯一的,并且不允许客户端插入两个_id字段相同的文档。

单字段

除了默认_id上的索引,MongoDB支持文档中单个字段上的用户自定义的索引创建,此索引可以是升序,也可以是降序。

对单字段索引和排序操作来说,索引键的排序顺序(升序或降序)无所谓,因为MongoDB可以从另一个方法遍历索引。

复合索引

MongoDB也支持对多字段的用户自定义索引,即,复合索引。

复合索引中字段的顺序是有意义的。例如,如果一个复合索引的组成为{userid:1, score: -1},那索引排序为首先对userid升序排序,然后对于userid相同的文档,按score的降序排序。

对复合索引和排序操作来说,索引键的排序顺序(升序或降序)将决定这个索引是否支持某种排序操作。详情可参见复合索引的索引顺序对最终排序顺序的影响。

参考复合索引多字段排序可获取复合索引的更多信息。

多键索引(Multikey Index)

MongoDB使用多键索引对存储在数组中的内容进行加索引。如果对一个拥有数组值的字段加索引,MongoDB创建此数组的每个元素上的索引。多键索引允许查询选择包含数组字段的文档,而匹配条件可以是数组的一个或多个元素。如果要被加索引的字段包含一个数组值,并且客户端不明确指定多键类型,那么MongoDB会自动决定是否创建多键索引。

如果要获取多键索引的更多信息,参见多键索引多键索引边界

以下可参考原文,点击此处跳转

地理空间索引(Geospatial Index)

...

...

MongoDB索引(一)的更多相关文章

  1. [DataBase] MongoDB (7) MongoDB 索引

    MongoDB 索引 1. 建立索引 唯一索引db.passport.ensureIndex( {"loginname": 1}, {"unique": tru ...

  2. MongoDB索引介绍

    MongoDB中的索引其实类似于关系型数据库,都是为了提高查询和排序的效率的,并且实现原理也基本一致.由于集合中的键(字段)可以是普通数据类型,也可以是子文档.MongoDB可以在各种类型的键上创建索 ...

  3. MongoDB(索引及C#如何操作MongoDB)(转载)

    MongoDB(索引及C如何操作MongoDB) 索引总概况 db.test.ensureIndex({"username":1})//创建索引 db.test.ensureInd ...

  4. MongoDB 索引篇

    MongoDB 索引篇 索引的简介 索引可以加快查询的速度,但是过多的索引或者规范不好的索引也会影响到查询的速度.且添加索引之后的对文档的删除,修改会比以前速度慢.因为在进行修改的时候会对索引进行更新 ...

  5. MongoDB索引的种类与使用

    一:索引的种类 1:_id索引:是绝大多数集合默认建立的索引,对于每个插入的数据,MongoDB都会自动生成一条唯一的_id字段2:单键索引: 1.单键索引是最普通的索引 2.与_id索引不同,单键索 ...

  6. MongoDB索引,性能分析

    索引的限制: 索引名称不能超过128个字符 每个集合不能超过64个索引 复合索引不能超过31列 MongoDB 索引语法 db.collection.createIndex({ <field&g ...

  7. MongoDB索引原理

    转自:http://www.mongoing.com/archives/2797 为什么需要索引? 当你抱怨MongoDB集合查询效率低的时候,可能你就需要考虑使用索引了,为了方便后续介绍,先科普下M ...

  8. MongoDB · 引擎特性 · MongoDB索引原理

    MongoDB · 引擎特性 · MongoDB索引原理数据库内核月报原文链接 http://mysql.taobao.org/monthly/2018/09/06/ 为什么需要索引?当你抱怨Mong ...

  9. MongoDB索引管理

    一.创建索引 创建索引使用db.collectionName.ensureIndex(...)方法进行创建: 语法: >db.COLLECTION_NAME.ensureIndex({KEY:1 ...

随机推荐

  1. CentOS 7.2 部署Saltstack

    CentOS 7.2部署Saltstack 一.环境介绍: 服务器名称 IP地址 Salt-Master 192.168.30.141 Slave1 192.168.30.131 Slave2 192 ...

  2. bind() unbind()绑定解绑事件

    .bind( eventType [, eventData], handler(eventObject)) 本文实例分析了JQuery中Bind()事件用法.分享给大家供大家参考.具体分析如下: .B ...

  3. java生成图片

    在一张图片上绘制别的图片以及文字. public String GenerateImage(WebCast_baseinfo base,String code,String customName,St ...

  4. Jenkins slave image

    Add a new shell script configure_slave.sh as following: #!/bin/bash dnf -openjdk git wget openssh-se ...

  5. android应用编译失败 ResXMLTree_node size 类错误,以及 android studio 项目内搜索

    今天很郁闷,又遇到个很让人崩溃的问题: ResXMLTree_node size 0 is smaller than header size 0x45. 类似这样的错误,提示中看不出任何有用的内容,网 ...

  6. SQL语句 不足位数补0

    select RIGHT('0000'+CAST( '123'  AS nvarchar(50)),4) DWBH 公式 RIGHT('位数'+CAST(要判断的字段 AS nvarchar(50)) ...

  7. 学习笔记_ADB常用指令

    ADB 查看连接到计算机的Android设备或模拟器 adb devices 说明: 正常显示状态应该是IP:Port State. State=device说明设备已经连接到计算机, State=o ...

  8. 页面加载与iframe加载函数

    <head> <script> $(document).ready(function(){ alert("a");   var wait = documen ...

  9. Java之IO流

    目录: 1.文件编码 2.File类 3.RandomAccessFile 4.字节流 5.字符流 6.对象的序列化和反序列化 1.文件编码 1)相关知识点 八进制和十六进制的表示方式:八进制前面加0 ...

  10. 【实验室笔记】C#的Socket客户端接收和发送数据

    采用socket发送和接收数据的实验中,服务器采用的是网络助手作为模拟服务器端. 客户端程序流程: 应用的命名空间: using System.Net; using System.Net.Socket ...