首页 > 数据库 >mongodb--索引

mongodb--索引

时间:2023-05-22 20:46:04浏览次数:30  
标签:-- mongodb 支持 查询 索引 字段 哈希 MongoDB

一、索引概述

1、说明:

索引是一种特殊的数据结构,即采用B-Tree数据结构。

索引是以易于遍历读取的形式存储着集合中文档的一小部分----即:文档中的特定字段或一/多组字段,并且这些字段均按照字段的值进行排序。

索引项的排序支持有效的等值匹配和基于范围的查询操作。

此外,MongoDB还可以使用索引中的排序返回排序的结果。

2、单字段索引

 MongoDB支持在文档的单个字段上创建用户定义的升序/降序索引,因此被称为单字段索引(Single Field Index)。

默认情况下,MongoDB中所有集合在“_id”字段上都有一个索引,用户也可以根据自己的需求添加额外索引来支持重要的查询和操作。

由于MongoDB可以从任何方向遍历索引,因此对于单个字段索引和排序操作来说,索引项的排序顺序(即升序或降序)并不重要。

3、复合索引

MongoDB除了支持单字段索引外,还支持复合索引。

所谓复合索引,就是包含多个字段的索引,一个复合索引最多可以包含31个字段。

需要注意的是,若某字段属于哈希索引,则这时复合索引就不能包括该字段。

4、多键索引

若文档中的字段为数组类型,则每个字段都是数组中的一个元素,MongoDB将会为数组中的每个元素创建索引,因此被称为多键索引(Multikey Index)。

多键索引允许通过匹配数组的一个或多个元素来查询包含该数组的文档。

注意:如果索引字段包含数组值,则MongoDB会自动确定是否创建多键索引,而无需显式地指定创建多键索引。

5、地理空间索引

为了支持对地理空间坐标数据的有效查询,MongoDB提供了两种特殊的索引,即返回结果时使用平面几何的二维索引(2d索引)和返回结果时使用球面几何的二维球面索引(2dsphere索引)。其中,2d索引支持在欧几里德平面上的计算,也支持计算球面上的距离;2dsphere索引支持球面上几何计算的查询,包含查询(在一个指定多边形内的位置进行查询)、 交集查询(查询指定几何相交的位置)和临近查询(如查询离另一个点最近的点)。我们可以通过将2d索引和2dsphere索引进行相结合,从而进行高效的地理空间查询。

6、文本索引

MongoDB提供了一种文本索引类型,支持在集合中搜索字符串内容,即进行文本检索查询。文本索引不存储特定语言的停止词,例如“the”、“a”以及“or”等词,而是将集合中的词作为词干,只存储根词。为了执行文本检索查询,则集合上必须有一个text索引。一个集合只能拥有一个文本检索索引,但是这个索引可以覆盖多个字段。

7、哈希索引

为了支持基于哈希分片键进行分片,MongoDB提供了哈希索引类型。哈希索引是使用哈希函数来计算索引字段的哈希值,若是该索引字段的哈希值在哈希索引的范围内,则分布的更加随机。需要注意的是,哈希索引只支持等值匹配,不支持基于范围的查询。

二、索引操作

1、查看索引

语法格式:

db.COLLECTION_NAME.getIndexes()

 

 

 

 

 

 

 

标签:--,mongodb,支持,查询,索引,字段,哈希,MongoDB
From: https://www.cnblogs.com/hyy-0/p/17421660.html

相关文章

  • MapReduce和Yarn原理
    MapReduce原理 问题1.什么是计算,什么是分布式计算?答案:计算指的是从海量数据中提取出有效的价值信息的过程(广义上解释),狭义上指的是1+1=2即:数学运算.分布式计算指的是多台机器协调,共同完成同1个计算任务.问题2:分布式计算的两种模式?答案:分散汇......
  • 马克思手稿中的数学题
    #define_CRT_SECURE_NO_WARNINGS#include<stdio.h>main(){ intx,y,z,number=0; printf("MenWomenChildren\n"); /*将变量x的可能取值依次代入方程组*/ for(x=0;x<=10;x++) { y=20-2*x; /*当x一定时,可确定y*/ z=30-x-y; /*当x......
  • Shell(Linux)手册
    资料来源Shell全面掌握教程|骏马金龙基础Bash中基本数据类型只有字符串类型echo123Bash中字符串的串联操作,直接将两段数据连接在一起即可,不需要任何操作符。echo"123""456"echo123456变量a=1echo$aa="www.cnblogs.com/mugetsukun"echo$aecho${#a}#获取......
  • 完数
    #define_CRT_SECURE_NO_WARNINGS#include<stdio.h>main(){ inti,j,s,n; printf("输入所范围的上限:"); scanf("%d",&n); for(j=2;j<=n;j++) { s=1; //保证每次循环i的初值为1 for(i=2;i<=j/2;i++) if(j%i==0)......
  • 换分币
    #define_CRT_SECURE_NO_WARNINGS#include<stdio.h>main(){ intx,y,z,count=1; printf("可能的兑换方法如下:\n"); for(x=0;x<=50;x+=10)/*x为1元硬币钱数,其取值为0,10,20,30,40,50*/ for(y=0;y<=50-x;y+=5) /*y为5角硬币钱数,其取值为0,5,10......
  • 5个视图扩展类,9个视图子类,视图集,drf之路由
    5个视图扩展类:1from.modelsimportBook2from.serializerimportBookSerialzier3fromrest_framework.responseimportResponse4fromrest_framework.genericsimportGenericAPIView56fromrest_framework.mixinsimportListModelMixin,CreateModelMixi......
  • 亲密数
    #define_CRT_SECURE_NO_WARNINGS#include<stdio.h>main(){ inti,j,s1,s2,n=3000; for(j=2;j<=n;j++) { s1=1; //保证每次循环i的初值为1 for(i=2;i<=j/2;i++) if(j%i==0) //判断i是否为j的因子 s1+=i; s2=1; //保证每次......
  • 自守数
    #define_CRT_SECURE_NO_WARNINGS#include<stdio.h>main(){ longi,j; for(i=0;i<=10000;i++) { for(j=10;;j*=10) if(i%j==i)break; if((i*i)%j==i)printf("%ld",i); }}......
  • 回文数
    ```#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>#defineN10voidmain(){   intn[N];   inti,j,k,s=0,flag,a;   for(i=0;i<=256;i++)   {       a=i*i;flag=1;s=1;       for(j=10;a/j!=0;s......
  • 基于matlab的LDPC译码算法误码率对比仿真,对比BP和BF译码
    1.算法仿真效果matlab2022a仿真结果如下:2.算法涉及理论知识概要LDPC码是麻省理工学院RobertGallager于1963年在博士论文中提出的一种具有稀疏校验矩阵的分组纠错码。几乎适用于所有的信道,因此成为编码界近年来的研究热点。它的性能逼近香农极限,且描述和实现简单,易于进行理论分......