Mongodb索引类型简介

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第88篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题,欢迎在文章下面点个赞,或者关注威赞。谢谢。

索引能够提高查询效率,本文结合官方文档,简单介绍索引的类型。不同类型的索引,能够支持不通过类型的数据和查询。

单字段索引

单字段索引使用集合中每个文档的一个字段来建立索引。下面的图描述了在集合Collection中使用score字段上建立的索引。score是一个数字类型的字段。索引使用score字段的数值建立。从最小值min到最大值max排列。其中还包括18, 30, 45, 75这几个数字。{score:1}表示按照字段score从小到大的顺序排列建立索引。

复合索引

复合索引是指使用集合中文档的两个或多个字段建立的索引。索引当中的数据,先按照第一个字段进行分组,再按照后续的字段依次分组。如下图所示,使用{userid:1, score:-1}建立索引,表示索引按照userid正序,score倒序进行排列。

在该索引当中,首先按照userid进行排列,如aa1, ca2, nb1, xyz. 然后再对索引的第二个字段score进行排序,如{user: 'ca2'}下面 ,包含75,55,30三个数据。

多键索引

多键索引使用数组当中的数据,构建索引。用户构建Mongodb的索引时,无需显示的告诉Mongodb建立的是多键索引。当Mongodb建立索引时,看到该字段是数组类型,mongodb则自动的创建一个多键索引。下图表示Mongodb建立的多键索引。

用户指定addr数组中的zip字段来建立索引。Mongodb看到addr是数组类型的字段,因此自动建立了多键索引。

地理信息索引

地理信息索引,能够提高Mongodb中,针对GeoJSON和位置坐标的查询性能。具体可以参考威赞前面发出来的文章。

Mongodb提功力两种地理信息索引

  • 二维平面地理信息索引,用来查询平面地理信息数据
  • 二维空间地理索引,用来查询曲面空间的地理信息数据。

其他索引类型

除了前面提到索引类型外,Mongodb还支持文本索引,哈希索引和集群索引等。这些索引介绍,可以参考威赞整理的其他文章。

相关推荐
颜颜yan_15 分钟前
时序数据库性能较量:金仓数据库如何在高负载场景中领跑InfluxDB
数据库·时序数据库
ChristXlx21 分钟前
Linux安装MongoDB(虚拟机适用)
linux·mongodb·postgresql
yfs102421 分钟前
PostgreSQL 16 + pgvector 完整安装和内网访问指南(Ubuntu 20.04)
数据库·ubuntu·postgresql
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ29 分钟前
查询MySQL数据库表的结构和数据
数据库·mysql·oracle
脸大是真的好~35 分钟前
MYSQL与B+树与索引相关面试题
数据库·b树·mysql
云和数据.ChenGuang36 分钟前
ELK 是一套**开源的日志收集、存储、分析与可视化的技术栈
服务器·数据库·elk·开源·运维技术·数据库运维工程师
MoonBit月兔38 分钟前
海外开发者实践分享:用 MoonBit 开发 SQLC 插件(其一)
数据库·缓存·wasm·moonbit
小高求学之路39 分钟前
eo4j 图数据库备忘单
数据库·neo4j
2301_7965125240 分钟前
React Native鸿蒙跨平台开发如何使用MongoDB或Firebase作为后端数据库来存储车辆信息、保养记录和预约信息
数据库·mongodb·react native
电商API_1800790524744 分钟前
主流电商平台 API 横向测评:淘宝、京东、拼多多接口能力与对接成本分析
大数据·开发语言·网络·数据库·人工智能