Mongodb索引的创建与命名

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

MongoDB支持用户添加索引,来提高针对某些字段重复查询的效率。本文通过整理官方文档,介绍Mongodb索引的创建和命名。

索引的创建

在Mongodb中,使用方法createIndex()来创建索引。当相同定义的索引在Mongodb当中不存在时,执行createIndex()时,就会创建该索引。而当索引已经存在时,创建带有相同名字的索引,Mongodb不会改变已有索引。创建带有不同名字的索引时,Mongodb会报错。

使用db.collection.createIndex()方法来创建索引。

复制代码
db.collection.createIndex(<索引字段和类型定义>,<索引选项>)

例如,为集合的name字段添加一个倒序索引。在Mongodb中,对于单字段索引的正序或者倒序排列都不会对性能有很大的影响。因为Mongodb在查询过程中,可以返序通过索引来查找。

复制代码
db.collection.createIndex( {name: -1})

查看创建的索引

使用下面的命令查看创建的索引。

复制代码
db.collection.getIndexes()

指定索引名称

在Mongodb创建索引时,用户可以为索引自定义名称。自定义索引名称能够方便区分其他索引。在查看解释计划的时候很容易的定位到是否使用带有自定义名称的索引。

为创建索引语句添加索引选项,来指定索引名称。

复制代码
db.collection.createIndex(
    {<field>, <value>},
    {name: "<indexName>"}
)

默认索引名称

当用户不指定索引名称是,Mongodb通过链接索引字段名称和用户指定的索引方向或类型作为索引名称来建立索引。如下面表格中定义的索引和名称。

|-----------------------------------------------|------------------------------------|
| 索引 | 默认名称 |
| { score: 1} | score_1 |
| {content: "text", "description.tags": "text"} | content_text_description.tags_text |
| {category: 1, locale: "2dsphere"} | category_1_locale_2dsphere |
| {fieldA: 1, fieldB: hashed, fieldC: -1} | fieldA_1_fieldB_hashed_fieldC_-1 |

注意事项

在创建索引前,用户需要考虑下面两个问题

    • 索引名称要唯一。使用集合中已经存在的索引名称建立新的索引,Mongodb会报错
    • 索引建立以后,不可以重新命名,用户必须删掉索引后,用新名字重新创建。

应用

为集合blog创建索引。

复制代码
db.blog.createIndex(
    {
        content: "text",
        "users.comments": "text",
        "users.profiles": "text"
    },
    {
        name: "InteractionsTextIndex"
    }
)

查看创建的索引

复制代码
db.blog.getIndexes()
相关推荐
智象科技2 分钟前
智象科技赋能金融、证券行业 IT 运维
大数据·运维·网络·数据库·科技·金融·智能运维
缘来如此҉1 小时前
Mysql数据库——增删改查CRUD
数据库·mysql·oracle
apihz2 小时前
域名WHOIS信息查询免费API使用指南
android·开发语言·数据库·网络协议·tcp/ip
gwcgwcjava2 小时前
[时序数据库-iotdb]时序数据库iotdb的安装部署
数据库·时序数据库·iotdb
SHUIPING_YANG2 小时前
根据用户id自动切换表查询
java·服务器·数据库
爱吃烤鸡翅的酸菜鱼2 小时前
IDEA高效开发:Database Navigator插件安装与核心使用指南
java·开发语言·数据库·编辑器·intellij-idea·database
超奇电子2 小时前
阿里云OSS预签名URL上传与临时凭证上传的技术对比分析
数据库·阿里云·云计算
神仙别闹2 小时前
基于C#+SQL Server实现(Web)学生选课管理系统
前端·数据库·c#
m0_653031363 小时前
PostgreSQL技术大讲堂 - 第97讲:PG数据库编码和区域(locale)答疑解惑
数据库·postgresql
会编程的林俊杰3 小时前
MySQL中的锁有哪些
数据库·mysql