第4章:MongoDB索引

第4章:MongoDB索引

4.1 索引基础

4.1.1 索引的重要性

  • 提高查询性能
  • 减少集合扫描
  • 支持高效排序

4.1.2 默认索引

javascript 复制代码
// _id字段的默认索引
{
    "_id": ObjectId("..."),
    "name": "示例文档"
}

4.2 索引类型

4.2.1 单字段索引

javascript 复制代码
// 创建单字段索引
db.users.createIndex({username: 1})  // 升序
db.users.createIndex({username: -1}) // 降序

// 查看集合索引
db.users.getIndexes()

4.2.2 复合索引

javascript 复制代码
// 创建复合索引
db.users.createIndex({
    lastName: 1, 
    firstName: 1
})

// 复合索引查询
db.users.find().sort({
    lastName: 1, 
    firstName: 1
})

4.2.3 唯一索引

javascript 复制代码
// 创建唯一索引
db.users.createIndex(
    {email: 1}, 
    {unique: true}
)

// 部分唯一索引
db.users.createIndex(
    {username: 1},
    {
        unique: true,
        partialFilterExpression: {age: {$gt: 18}}
    }
)

4.2.4 文本索引

javascript 复制代码
// 创建文本索引
db.articles.createIndex(
    {content: "text"},
    {
        weights: {
            content: 10,
            tags: 5
        },
        name: "content_text_index"
    }
)

// 文本搜索
db.articles.find({
    $text: {$search: "MongoDB 数据库"}
})

4.2.5 地理空间索引

javascript 复制代码
// 创建2dsphere索引
db.places.createIndex({location: "2dsphere"})

// 地理位置查询
db.places.find({
    location: {
        $near: {
            $geometry: {
                type: "Point",
                coordinates: [116.4, 39.9]
            },
            $maxDistance: 1000
        }
    }
})

4.3 索引性能分析

4.3.1 查询执行计划

javascript 复制代码
// 分析查询性能
db.users.find({username: "example"}).explain("executionStats")

// 查看索引使用情况
db.users.find({username: "example"}).hint({username: 1})

4.3.2 索引选择策略

javascript 复制代码
// 创建复合索引
db.products.createIndex({
    category: 1, 
    price: -1
})

// 高效查询
db.products.find({
    category: "电子产品",
    price: {$gt: 1000}
}).sort({price: -1})

4.4 索引管理

4.4.1 索引操作

javascript 复制代码
// 删除指定索引
db.users.dropIndex({username: 1})

// 删除所有索引(除_id)
db.users.dropIndexes()

// 重建索引
db.users.reIndex()

4.4.2 后台创建索引

javascript 复制代码
// 后台创建索引(不阻塞写操作)
db.users.createIndex(
    {username: 1}, 
    {background: true}
)

4.5 常见索引问题

4.5.1 索引开销

  • 写入性能下降
  • 额外存储空间
  • 定期评估和调整

4.5.2 最佳实践

  1. 仅为常用查询创建索引
  2. 避免过多索引
  3. 使用复合索引替代多个单字段索引
  4. 定期分析和优化
相关推荐
m0_4665252924 分钟前
绿盟科技风云卫AI安全能力平台成果重磅发布
大数据·数据库·人工智能·安全
爱学习的阿磊1 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
枷锁—sha1 小时前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞1 小时前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean1 小时前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_550024631 小时前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦1 小时前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_99992 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7652 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码2 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql