Mongodb索引的删除

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第87篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题,欢迎在文章下面点个赞,或者关注威赞。谢谢。

Mongodb的索引,大多时间都会提高集合的数据查询效率。但针对查询字段的多个索引,可能会使Mongodb选择错误的索引,而对查询效率产生负面影响。同时,数据库管理人员也需要定期查看索引的使用情况 ,需要将不使用的索引清理掉。减少对数据插入和更新产生的影响。而在索引的构建输入错误的名称,或者重新命名索引时,也需要删除索引。

本文整理官方文档,介绍Mongodb索引的删除。

删除索引的方法

删除一个索引

复制代码
db.collection.dropIndex()

删除多个索引

复制代码
db.collection.dropIndexes()

当用户不指定索引名称数组时,删除除_id字段的所有索引。当用户指定索引名称数组时,按照用户指定数组名称删除数组。

注意事项

  • 当用户想要删除_id字段索引时,需要把集合删除。
  • 当用户删除索引时,应用的查询性能可能会产生影响。因此Mongodb建议先将索引隐藏,当确定对应用没有过大的影响时,才删除索引。

应用

使用getIndexes()方法,获取索引名称。

复制代码
db.collection.getIndexes()

删除单个索引

复制代码
db.collection.dropIndex("<indexName>")

删除多个索引

复制代码
db.collection.dropIndexes(["<indexName1>","<indexName1>",...])

删除除了_id索引的其他索引

复制代码
db.collection.dropIndexes()

删除后,使用getIndexes()查看索引

复制代码
db.collection.getIndexes()
相关推荐
小吴编程之路5 小时前
MySQL 索引核心特性深度解析:从底层原理到实操应用
数据库·mysql
~莫子5 小时前
MySQL集群技术
数据库·mysql
凤山老林5 小时前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
就不掉头发5 小时前
Linux与数据库进阶
数据库
与衫5 小时前
Gudu SQL Omni 技术深度解析
数据库·sql
咖啡の猫6 小时前
Redis桌面客户端
数据库·redis·缓存
oradh6 小时前
Oracle 11g数据库软件和数据库静默安装
数据库·oracle
what丶k6 小时前
如何保证 Redis 与 MySQL 数据一致性?后端必备实践指南
数据库·redis·mysql
_半夏曲6 小时前
PostgreSQL 13、14、15 区别
数据库·postgresql
把你毕设抢过来6 小时前
基于Spring Boot的社区智慧养老监护管理平台(源码+文档)
数据库·spring boot·后端