MongoDB【五】索引

ops/2024/9/25 23:24:36/

在MongoDB中,索引对于提升查询性能至关重要,特别是针对大型数据集时。以下是如何在MongoDB中创建、查看和删除索引的基本操作,以及不同类型的索引如何影响查询性能。

创建索引

1. 创建单字段索引

  • 升序索引(默认):
    db.collection.createIndex({ fieldName: 1 }) // 或者 db.collection.ensureIndex({ fieldName: 1 })
    
  • 降序索引:
    db.collection.createIndex({ fieldName: -1 })
    

2. 创建复合索引

db.collection.createIndex({ field1: 1, field2: -1 })

这将创建一个索引,首先按照field1升序,然后在field1相等的情况下按照field2降序。

3. 创建唯一索引

db.collection.createIndex({ fieldName: 1 }, { unique: true })

独特索引确保集合中的字段值唯一,防止重复项。

4. 创建地理空间索引

db.places.createIndex({ location: "2dsphere" })

此索引用于支持地理位置相关的查询,如距离搜索、几何形状内包含点的查找等。

查看索引

  • 列出集合上的所有索引:

    db.collection.getIndexes()
    
  • 查看索引大小和其他统计信息:

    db.collection.totalIndexSize()
    

删除索引

  • 删除特定索引:

    db.collection.dropIndex("fieldName_1_fieldName_2") // 根据索引名称删除
    

    或者

    db.collection.dropIndex({ fieldName: 1, fieldName2: -1 }) // 根据索引键删除
    
  • 删除集合上的所有索引(除了 _id 索引,它是自动创建且不能被删除的):

    db.collection.dropIndexes()
    

索引对查询性能的影响

  • 查询性能提升:索引可以帮助数据库快速定位到所需文档,避免全表扫描,显著减少查询响应时间。

  • 写入性能折损:每次插入、更新或删除文档时,MongoDB都需要维护索引,这会导致写入操作的性能下降,尤其是当索引较多或者数据更新频繁时。

  • 唯一索引:不仅可以加速查找,还强制字段值唯一性,有助于数据完整性。

  • 复合索引:在多个字段上创建索引时,MongoDB可以利用索引来优化涉及多个字段的查询条件,特别是在查询条件顺序与索引键顺序一致时效果最佳。

  • 地理空间索引:特别适用于GIS应用,能够高效地处理基于经纬度的地理位置查询。

因此,在设计索引策略时,需要根据实际查询模式和业务需求进行权衡,并定期审查和调整索引结构以保持最优性能。同时,考虑到磁盘空间占用和维护成本,不建议无目的地创建大量索引。


http://www.ppmy.cn/ops/11324.html

相关文章

细说postgresql之pg_rman备份恢复 —— 筑梦之路

pg_rman是一款开源的备份恢复软件,支持在线和基于PITR的备份恢复方式。 pg_rman类似于oracle的rman,可以进行全量、增量、归档日志的备份。 运行模式: 安装部署 Releases ossc-db/pg_rman GitHub 1、需要根据PG Server的版本,下…

【监控zabbix】zabbix监控误报-参数优化

本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》:python零基础入门学习 《python运维脚本》: python运维脚本实践 《shell》:shell学习 《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战 《k8…

C语言结构体介绍

文章目录 前言一、结构的基础知识二、结构的声明三、结构体成员的类型四、结构体变量的定义和初始化1. 结构体变量的定义2. 结构体变量的初始化 五、结构体成员的访问六、结构体传参总结 前言 C语言结构体的基础知识,结构体的声明,结构体成员的类型&…

9月BTE第8届广州国际生物技术大会暨展览会,全媒体聚焦下的高精尖行业盛会

政策春风助力,共迎大湾区生物医药行业50亿红利 今年3月“创新药”首次写入国务院政府工作报告之后,广州、珠海、北京多地政府纷纷同步出台了多项细化政策,广州最高支持额度高达50亿元,全链条为生物医药产业提供资金支持&#xff…

Oracle-操作【Python-cx_oracle】

一、cx_oracle 1 简介 通过Python扩展模块cx_Oracle访问Oracle数据库cx_Oracle通常使用 pip 安装Oracle 客户端库需要单独安装 2 特点 支持多个 Oracle 客户端和数据库版本执行 SQL 和 PL/SQL 语句广泛的 Oracle 数据类型支持,包括大型对象(CLOB 和 …

光伏无人机勘探技术应用分析

光伏无人机勘探与传统勘探想必,具有智能化作业、测控精度高、环境适应性强等明显优势;卫星勘探辅助其能更快速甚至实时完成测绘拼图;在进行勘察时,可根据需要自由更换机载设备;自动诗经建模使数据更直观,工…

python常见语法

变量赋值: my_var 10 基本数据类型: 整数(int)、浮点数(float)、字符串(str)、布尔值(bool)、列表(list)、元组(tuple&…

视频不够清晰怎么办?教你几种有效方法

在我们日常生活中,有时候我们会遇到不清晰的视频,这给我们带来了很多不便。那么,怎么将不清晰的视频变清晰呢?本文将为您介绍一些常用的软件工具,帮助您提升视频的清晰度。 方法一:使用AI技术 AI技术可以通…