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还支持文本索引,哈希索引和集群索引等。这些索引介绍,可以参考威赞整理的其他文章。

相关推荐
海南java第二人4 小时前
Nebula Graph 实战:基于图数据库存储 CMDB 实体关系
数据库·图数据库·nebula
曹牧5 小时前
oracle:“not all variables bound”
数据库·oracle
数据库百宝箱5 小时前
Oracle RMAN Image Copy 本地恢复
数据库·oracle
zuYM4g7Dp6 小时前
NoSql数据库设计心得
数据库·nosql
睡不醒男孩0308237 小时前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
cmes_love8 小时前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
swordbob8 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q9 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
十五年专注C++开发9 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
数据库小学妹9 小时前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai