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 的查询效率。如果你在项目中有使用哪种索引,或者需要进一步了解某种索引的具体用法,欢迎在评论区讨论!

相关推荐
前端双越老师19 小时前
Skills 是什么?如何用于 Agent 开发?
人工智能·node.js·agent
San301 天前
AI 时代的“USB-C”接口:MCP 核心原理与实战
langchain·node.js·mcp
helloweilei3 天前
javascript 结构化克隆
javascript·node.js
小蜜蜂dry3 天前
nestjs学习 - 控制器、提供者、模块
前端·node.js·nestjs
San303 天前
手写 Mini Cursor:基于 Node.js 与 LangChain 的开发实战
langchain·node.js·agent
前端付豪4 天前
Nest 项目小实践之图书增删改查
前端·node.js·nestjs
sunny_4 天前
面试踩大坑!同一段 Node.js 代码,CJS 和 ESM 的执行顺序居然是反的?!99% 的人都答错了
前端·面试·node.js
Qinana5 天前
150行代码搞定私有知识库!Node.js + LangChain 打造最小化 RAG 系统全流程
人工智能·程序员·node.js
一次旅行5 天前
npm-error code 128问题解决方法
node.js