原文: https://beginnersbook.com/2017/09/mongodb-indexing-tutorial-with-example/

MongoDB 中的索引是一种特殊的数据结构,它保存创建索引的少量文档字段的数据。索引提高了数据库中搜索操作的速度,因为不是搜索整个文档,而是对仅包含少量字段的索引执行搜索。另一方面,由于索引使用了额外的写入和额外数据空间,索引太多会妨碍插入,更新和删除操作的性能。

如何在 MongoDB 中创建索引

语法:

  1. db.collection_name.createIndex({field_name: 1 or -1})

值 1 表示升序,-1 表示降序。

例如,我有一个集合studentdata。此集合中的文档包含以下字段:student_namestudent_idstudent_age

假设我想按升序在student_name字段上创建索引:

  1. db.studentdata.createIndex({student_name: 1})

输出:

  1. {
  2. "createdCollectionAutomatically" : false,
  3. "numIndexesBefore" : 1,
  4. "numIndexesAfter" : 2,
  5. "ok" : 1
  6. }

MongoDB 索引教程 - 图1

我们在student_name上创建了索引,这意味着当有人根据student_name搜索文档时,搜索速度会更快,因为索引将用于此搜索。因此,在字段中创建将在集合中频繁搜索的索引非常重要。

MongoDB - 查找集合中的索引

我们可以使用getIndexes()方法来查找在集合上创建的所有索引。此方法的语法是:

  1. db.collection_name.getIndexes()

因此,要获取studentdata集合的索引,命令将是:

  1. > db.studentdata.getIndexes()
  2. [
  3. {
  4. "v" : 2,
  5. "key" : {
  6. "_id" : 1
  7. },
  8. "name" : "_id_",
  9. "ns" : "test.studentdata"
  10. },
  11. {
  12. "v" : 2,
  13. "key" : {
  14. "student_name" : 1
  15. },
  16. "name" : "student_name_1",
  17. "ns" : "test.studentdata"
  18. }
  19. ]

输出显示我们在此集合中有两个索引。在_id上创建的默认索引以及我们在student_name字段上创建的索引。

MongoDB - 删除集合中的索引

您可以删除特定索引或所有索引。

删除特定索引:

为此,使用了dropIndex()方法。

  1. db.collection_name.dropIndex({index_name: 1})

让我们删除我们在集合studentdata中的student_name字段上创建的索引。这个命令:

  1. db.studentdata.dropIndex({student_name: 1})

MongoDB 索引教程 - 图2

nIndexesWas:显示执行此命令之前有多少索引

ok: 1:表示命令执行成功。

删除所有索引:

要删除集合的所有索引,我们使用dropIndexes()方法。

dropIndexs()方法的语法:

  1. db.collection_name.dropIndexes()

假设我们想要删除studentdata集合的所有索引。

  1. db.studentdata.dropIndexes()

MongoDB 索引教程 - 图3

消息“为集合删除的非_id索引”表示默认索引_id仍将保留,不能删除。这意味着使用此方法我们只能删除我们创建的索引,我们不能删除在_id字段上创建的默认索引。