4-MongoDB索引知识

简介: MongoDB索引基于B树结构,可显著提升查询效率,避免全表扫描。支持单字段、复合、地理空间、文本及哈希索引,适用于多种查询场景,如范围查询、排序、全文搜索等,合理使用索引能大幅提升数据库性能。

4.1 概述
索引支持在MongoDB中高效地执行查询。如果没有索引,MongoDB必须执行全集合扫描,即扫描集合中的每个文档,以选择与查询语句匹配的文档。这种扫描全集合的查询效率是非常低的,特别在处理大量的数据时,查询可以要花费几十秒甚至几分钟,这对网站的性能是非常致命的。
如果查询存在适当的索引,MongoDB可以使用该索引限制必须检查的文档数。 索引是特殊的数据结构,它以易于遍历的形式存储集合数据集的一小部分。索引存储特定字段或一组字段的值,按字段值排序。索引项的排序支持有效的相等匹配和基于范围的查询操作。此外,MongoDB还可以使用索引中的排序返回排序结果。 MongoDB索引使用B树数据结构(确切的说是B-Tree,MySQL是B+Tree)
官网文档:https://docs.mongodb.com/manual/indexes/
4.2 索引的类型
4.2.1 单字段索引
MongoDB支持在文档的单个字段上创建用户定义的升序/降序索引,称为单字段索引(Single Field Index)。 对于单个字段索引和排序操作,索引键的排序顺序(即升序或降序)并不重要,因为MongoDB可以在任何方向上遍历索引。
4.2.2 复合索引
MongoDB还支持多个字段的用户定义索引,即复合索引(Compound Index)。复合索引中列出的字段顺序具有重要意义。例如,如果复合索引由 { userid: 1, score: -1 } 组成,则索引首先按userid正序排序,然后在每个userid的值内,再在按score倒序排序。
4.2.3 其他索引
地理空间索引(Geospatial Index)
为了支持对地理空间坐标数据的有效查询,MongoDB提供了两种特殊的索引:返回结果时使用平面几何的二维索引和返回结果时使用球面几何的二维球面索引。
文本索引(Text Indexes)
MongoDB提供了一种文本索引类型,支持在集合中搜索字符串内容。这些文本索引不存储特定于语言的停止词(例如“the”、“a”、“or”), 而将集合中的词作为词干,只存储根词。
哈希索引(Hashed Indexes)
为了支持基于散列的分片,MongoDB提供了散列索引类型,它对字段值的散列进行索引。这些索引在其范围内的值分布更加随机,但只支持相等匹配,不支持基于范围的查询。

相关文章
|
1天前
|
机器学习/深度学习 存储 边缘计算
物联网平台实战:从设备接入到数据分析的端到端架构演进
本文系统阐述物联网平台从设备接入到数据分析的架构演进路径,涵盖多协议接入、边缘计算、实时处理与AI集成等关键技术,分享高并发优化、分层存储、安全认证等实战经验,助力企业构建高效、可扩展的IoT平台,推动数字化转型与智能决策。
|
1天前
|
Java API Maven
[MES]不合格订单接入提醒功能(☆☆☆)
克隆或下载代码至IDEA,配置JDK、Maven等环境,遇问题主动请教同事或组长。运行项目后,针对“不合格工单超30分钟需通知”需求,结合定时任务与短信/钉钉API实现。涉及Git、Maven、SpringBoot技术。
|
1天前
|
消息中间件 物联网 测试技术
幂等方案专题
适用于科技公司服务器及物联网设备异常时的语音告警通知。开通语音服务后,可申请资质、话术与模板,支持变量替换,通过API调用实现自动拨打电话播报告警内容,并可通过控制台或API查询呼叫记录,支持消息回执推送,保障告警及时处理。
|
1天前
|
机器学习/深度学习 存储 边缘计算
物联网平台实战:从设备接入到数据分析的端到端架构演进
本文详解物联网平台从设备接入到数据分析的架构演进路径,涵盖多协议接入、边缘计算、实时处理与AI集成等核心技术,分享高并发优化、分层存储、安全认证等实战经验,助力企业构建高效、可扩展的IoT系统,推动数字化转型与智能决策升级。(238字)
|
1天前
|
存储 缓存 安全
One Trick Per Day
Map初始化应避免容量设置不当,建议用Guava指定预期大小;禁用Executors创建线程池,防止OOM,推荐手动定义参数或使用Guava;Arrays.asList返回不可变集合,禁止修改操作;遍历Map优先使用entrySet或forEach提升性能;SimpleDateFormat非线程安全,禁用static修饰,推荐ThreadLocal或Java8新时间类;并发修改记录需加锁,优先乐观锁(version控制),冲突低时重试不少于3次。
|
1天前
|
弹性计算 运维 安全
自动化运维实战:利用运维编排OOS批量管理数百台ECS
阿里云运维编排服务(OOS)助力企业高效管理大规模ECS集群,支持批量操作、任务编排、定时执行与安全管控,实现运维自动化。相比传统人工操作,效率提升超95%,显著降低错误率,构建标准化、可复用的智能运维体系。
|
1天前
|
测试技术
发布模式
蓝绿部署是一种减少发布中断的策略,通过维护两套系统(绿为线上,蓝为新版本)实现快速切换与回滚。金丝雀发布则逐步替换旧系统,适用于大规模集群。A/B测试用于比较不同版本效果,非发布策略。三者各有适用场景。
|
1天前
|
弹性计算 运维 监控
混合云降本之道:通过CEN连接IDC与云上弹性资源
阿里云CEN助力企业构建高性价比混合云,打通IDC与云端资源,实现弹性扩展、智能调度与成本优化。通过专线互联、自动扩缩容和统一管理,显著降低硬件、网络与运维成本,广泛适用于电商、金融等场景,成为数字化转型主流选择。(238字)
|
1天前
|
存储 缓存 监控
EFC&CTO:缓存引发数据不一致问题排查与深度解析
EFC客户端更新缓存架构后,在NAS场景CTO测试中出现data mismatch。经排查,因分布式缓存版本号回退,导致旧NULL数据被读入pagecache并刷入文件系统,破坏了正常数据。通过维护递增版本号修复,最终测试通过。
|
1天前
|
弹性计算 安全 Serverless
预留实例券 vs 节省计划:哪种计费方式更适合你的业务?
企业云成本如何从“可变”转为“可控”?阿里云预留实例券(RI)与节省计划(SP)是两大利器。RI适合长期稳定业务,折扣高但灵活性低;SP覆盖广、管理简单,适配弹性多变场景。本文通过四维对比与决策树,助您按业务特性选择最优方案,实现成本从消耗到战略投资的转变。(238字)