MongoDB 索引类型详解

MongoDB 索引类型详解

在 MongoDB 中,索引是提高查询效率、优化数据库性能的重要手段。MongoDB 支持多种类型的索引,每种索引类型适用于不同的查询需求和场景。本文将详细介绍 MongoDB 中几种常见的索引类型、示例及其限制。

1. 单字段索引(Single Field Index)
  • 示例 :对 age 字段创建单字段索引。

    javascript 复制代码
    db.users.createIndex({ age: 1 });
  • 限制:只能对单个字段进行索引,无法优化多字段查询¹。

2. 复合索引(Compound Index)
  • 示例 :对 nameage 字段创建复合索引。

    javascript 复制代码
    db.users.createIndex({ name: 1, age: -1 });
  • 限制:最多包含 32 个字段,查询时必须包含索引的前缀字段²。

3. 多键索引(Multikey Index)
  • 示例 :对包含数组的 tags 字段创建多键索引。

    javascript 复制代码
    db.articles.createIndex({ tags: 1 });
  • 限制:一个集合中不能有多个多键索引,且不能与文本索引或稀疏索引组合使用²。

4. 地理空间索引(Geospatial Index)
  • 示例 :对 location 字段创建 2dsphere 地理空间索引。

    javascript 复制代码
    db.places.createIndex({ location: "2dsphere" });
  • 限制:只能用于地理空间数据,且查询必须使用地理空间操作符²。

5. 文本索引(Text Index)
  • 示例 :对 description 字段创建文本索引。

    javascript 复制代码
    db.products.createIndex({ description: "text" });
  • 限制:每个集合只能有一个文本索引,且不支持中文分词²。

6. 哈希索引(Hashed Index)
  • 示例 :对 user_id 字段创建哈希索引。

    javascript 复制代码
    db.sessions.createIndex({ user_id: "hashed" });
  • 限制:仅支持等值查询,不支持范围查询²。

7. 通配符索引(Wildcard Index)
  • 示例 :对 userMetadata 字段及其所有子字段创建通配符索引。

    javascript 复制代码
    db.users.createIndex({ "userMetadata.$**": 1 });
  • 限制 :性能可能不如特定字段索引,且不支持 $text 操作符²。

8. TTL 索引(TTL Index)
  • 示例 :对 createdAt 字段创建 TTL 索引,使文档在指定时间后自动删除。

    javascript 复制代码
    db.logs.createIndex({ createdAt: 1 }, { expireAfterSeconds: 3600 });
  • 限制:只能用于单个日期字段,且字段类型必须是日期类型²。

总结

这些索引类型可以帮助优化查询性能,满足不同的应用需求。选择合适的索引类型可以显著提高 MongoDB 的查询效率。如果你在项目中有使用哪种索引,或者需要进一步了解某种索引的具体用法,欢迎在评论区讨论!

相关推荐
叫我Paul就好7 小时前
尝试 Node 搭建后端-开发框架
node.js
葫芦和十三1 天前
图解 MongoDB 12|索引与查询优化地图:一条主线,三个判断轴
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 11|慢查询排查闭环:从 Profile 到 explain 的分层路径
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 09|explain 再读:从 queryPlanner 到 executionStats
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 10|覆盖查询:让索引把活干完,根本不用回表
后端·mongodb·agent
风止何安啊2 天前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
糖拌西瓜皮2 天前
Node.js核心模块实战:文件、路径、HTTP与流处理
javascript·node.js
糖拌西瓜皮2 天前
Node.js工程化实践:包管理、TypeScript配置与代码质量
typescript·node.js
糖拌西瓜皮2 天前
NestJS入门指南:Java开发者的Spring Boot体验
javascript·node.js
糖拌西瓜皮2 天前
Express框架快速上手:中间件、路由与错误处理
javascript·node.js