服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - MongoDB - MongoDB索引的用法介绍

MongoDB索引的用法介绍

2022-10-09 16:12springsnow MongoDB

这篇文章介绍了MongoDB索引的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录。

这种扫描全集合的查询效率是非常低的,特别在处理大量的数据时,查询可以要花费几十秒甚至几分钟,这对网站的性能是非常致命的。

索引是特殊的数据结构,索引存储在一个易于遍历读取的数据集合中,索引是对数据库表中一列或多列的值进行排序的一种结构

一、索引

1、createIndex() 方法

MongoDB使用 createIndex() 方法来创建索引。

注意在 3.0.0 版本前创建索引方法为 db.collection.ensureIndex(),之后的版本使用了 db.collection.createIndex() 方法,ensureIndex() 还能用,但只是 createIndex() 的别名。

语法

createIndex()方法基本语法格式如下所示:

?
1
db.collection.createIndex(keys, options)

语法中 Key 值为你要创建的索引字段,1 为指定按升序创建索引,如果你想按降序来创建索引指定为 -1 即可。

实例

?
1
db.col.createIndex({"title":1})

createIndex() 方法中你也可以设置使用多个字段创建索引(关系型数据库中称作复合索引)。

?
1
db.col.createIndex({"title":1,"description":-1})

createIndex() 接收可选参数,可选参数列表如下:

MongoDB索引的用法介绍

在后台创建索引:

?
1
db.values.createIndex({open: 1, close: 1}, {background: true})

通过在创建索引时加 background:true 的选项,让创建工作在后台执行

2、其他

1、查看集合索引

?
1
db.col.getIndexes()

2、查看集合索引大小

?
1
db.col.totalIndexSize()

3、删除集合所有索引

?
1
db.col.dropIndexes()

4、删除集合指定索引

?
1
db.col.dropIndex("索引名称")

二、全文索引

1、创建全文索引

考虑以下 posts 集合的文档数据,包含了文章内容(post_text)及标签(tags):

?
1
2
3
4
5
6
7
{
   "post_text": "enjoy the mongodb articles on Runoob",
   "tags": [
      "mongodb",
      "runoob"
   ]
}

我们可以对 post_text 字段建立全文索引,这样我们可以搜索文章内的内容:

?
1
db.posts.ensureIndex({post_text:"text"})

2、使用全文索引

现在我们已经对 post_text 建立了全文索引,我们可以搜索文章中的关键词 runoob:

?
1
db.posts.find({$text:{$search:"runoob"}})

以下命令返回了如下包含 runoob 关键词的文档数据:

?
1
2
3
4
5
{
   "_id" : ObjectId("53493d14d852429c10000002"),
   "post_text" : "enjoy the mongodb articles on Runoob",
   "tags" : [ "mongodb", "runoob" ]
}

使用全文索引可以提高搜索效率。

3、删除全文索引

删除已存在的全文索引,可以使用 find 命令查找索引名:

?
1
db.posts.getIndexes()

通过以上命令获取索引名,本例的索引名为post_text_text,执行以下命令来删除索引:

?
1
db.posts.dropIndex("post_text_text")

到此这篇关于MongoDB索引的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://www.cnblogs.com/springsnow/p/13295129.html

延伸 · 阅读

精彩推荐
  • MongoDBMongoDB简单操作示例【连接、增删改查等】

    MongoDB简单操作示例【连接、增删改查等】

    这篇文章主要介绍了MongoDB简单操作,涉及命令行窗口下使用MongoDB进行简单的连接、增删改查等相关操作技巧,需要的朋友可以参考下 ...

    tinyphp3102020-05-23
  • MongoDBmongodb 查看数据库和表大小

    mongodb 查看数据库和表大小

    mongodb查看数据库和表的方法比较简单,在为这里推荐使用stats的方法,直观并且详细。 ...

    MongoDB教程网15472020-04-26
  • MongoDBMongodb启动命令参数中文说明

    Mongodb启动命令参数中文说明

    这篇文章主要介绍了Mongodb启动命令参数中文说明,本文包括基本配置、主/从参数、Sharding(分片)选项等内容,需要的朋友可以参考下 ...

    MongoDB教程网2472020-04-29
  • MongoDB浅谈MongoDB的备份方式

    浅谈MongoDB的备份方式

    mongodb数据库同样离不开必要的维护,如备份、恢复、导入、导出。其实备份和恢复比导入和导出要方便些,而且一般不会出错,所以大部分时候使用备份和...

    MongoDB教程网4642020-05-03
  • MongoDBMongoDB为用户设置访问权限

    MongoDB为用户设置访问权限

    MongoDB已经使用很长一段时间了,基于MongoDB的数据存储也一直没有使用到权限访问 MongoDB默认设置为无权限访问限制 ...

    MongoDB教程网5152020-04-21
  • MongoDBMongoDB 主从复制实例讲解

    MongoDB 主从复制实例讲解

    这篇文章主要介绍了MongoDB 主从复制实例讲解,主从复制可以用来数据库备份,故障恢复,读写分离,有兴趣的小伙伴可以参考下本文 ...

    lqding19802512020-05-08
  • MongoDBmongodb数据库实验之增删查改

    mongodb数据库实验之增删查改

    这篇文章主要介绍了mongodb数据库实验之增删查改的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    segmentfault8082020-12-28
  • MongoDBMongoDB Remove函数的3个常见用法

    MongoDB Remove函数的3个常见用法

    这篇文章主要介绍了MongoDB Remove函数的3个常见用法,需要的朋友可以参考下 ...

    MongoDB教程网6322020-04-24