Docs 菜单
Docs 主页
/
MongoDB Manual
/ / /

db.collection.createIndex()

在此页面上

  • 定义
  • 兼容性
  • 语法
  • 选项
  • 行为
  • 示例
  • 更多信息

带驱动程序的 MongoDB

C#Java SyncNode.jsPyMongoCC++GoJava RSKotlin CoroutineKotlin SyncPHPMotorMongoidRustScalaSwift
db.collection.createIndex(keys, options, commitQuorum)

对集合创建索引。

为了最大限度地减少构建索引对副本集和分片集群的影响,请使用滚动索引构建过程,如 在副本集上构建滚动索引中所述。

此方法可用于以下环境中托管的部署:

  • MongoDB Atlas:用于云中 MongoDB 部署的完全托管服务

注意

所有 MongoDB Atlas 集群都支持此命令。有关 Atlas 对所有命令的支持的信息,请参阅不支持的命令

createIndex() 方法采用以下形式:

db.collection.createIndex( <keys>, <options>, <commitQuorum>)

createIndex() 方法使用以下参数:

Parameter
类型
说明

keys

文档

包含字段和值对的文档,其中字段是索引键,值描述该字段的索引类型。

对于字段的升序索引,指定值为 1。对于降序索引,请指定值 -1

星号 (*) 不是有效的索引名称。

MongoDB 支持多种不同的索引类型,包括:

有关更多信息,请参阅索引类型

通配符索引支持用户对集合中的自定义字段或大量不同字段进行查询的工作负载。

  • 您可以为特定字段及其子路径或文档中的所有字段创建通配符索引。

    有关详细信息,请参阅通配符索引

options

文档

可选。设立控制索引创建的选项的文档。详情请参阅选项。

整数或字符串

可选。承载数据的投票副本集成员的最小数量(即提交法定节点数),包括主节点,必须在主节点将indexes标记为就绪之前报告索引构建成功。“投票”成员是members[n].votes大于0的任何副本集成员。

支持以下值:

  • "votingMembers" - 所有承载数据的有投票权副本集成员(默认)。

  • "majority" - 数据承载投票副本集成员的简单多数制。

  • <int> - 特定数量的承载数据的副本集投票节点。

  • 0 - 禁用法定人数投票行为。成员同时开始索引构建,但在完成索引构建之前投票或等待法定人数。如果您使用 0 的提交法定人数启动索引构建,则以后无法使用 setIndexCommitQuorum 修改提交法定人数。

  • 副本集标记名称

options 文档包含一组控制索引创建的选项。不同索引类型可以有特定于该类型的附加选项。

可以在同一文档中指定多个索引选项。 但是,如果指定多个选项文档,则db.collection.createIndex()操作将失败。

请考虑下面的 db.collection.createIndex() 操作:

db.collection.createIndex(
{
"a": 1
},
{
unique: true,
sparse: true,
expireAfterSeconds: 3600
}
)

如果选项规范被拆分为多个文档(如下所示: { unique: true }, { sparse: true, expireAfterSeconds: 3600 } ),索引创建操作将失败。

除非另有说明,否则以下选项可用于所有索引类型:

Parameter
类型
说明

unique

布尔

可选。 创建唯一索引,以便集合不会接受索引键值与索引中现有值匹配的文档插入或更新。

指定 true 可创建唯一索引。默认值为 false

该选项不适用于哈希索引

name

字符串

可选。索引名称。如果未指定,MongoDB 将通过连接索引字段的名称和排序顺序来生成索引名称。

partialFilterExpression

文档

可选。如果指定,索引只引用与过滤器表达式匹配的文档。有关更多信息,请参阅部分索引

过滤器表达式可以包括:

您可以为所有 MongoDB索引类型指定 partialFilterExpression 选项。

版本 3.2 中的新增功能

sparse

布尔

可选。 如果为true,则索引仅引用具有指定字段的文档。这些索引使用的空间较少,但在某些情况下(尤其是排序),其行为会有所不同。 默认值为false 。有关更多信息,请参阅稀疏索引

以下索引类型默认为稀疏索引,忽略此选项:

对于包含 2dsphere 索引键以及其他类型的键的复合索引,只有 2dsphere 索引字段可确定索引是否引用文档。

提示

部分索引可提供比稀疏索引更多的功能。除非您的应用程序有特定要求,否则请使用部分索引而不是稀疏索引。

expireAfterSeconds

整型

可选。指定以秒为单位的生存时间 (TTL) 值,以便控制 MongoDB 在此集合中保留文档的时长。此选项仅会应用于 TTL 索引。请参阅通过设置 TTL 使集合中的数据过期以了解更多信息。

如果您使用 MongoDB 5.0 之前版本创建的 TTL 索引,或者要将 MongDB 5.0 创建的数据与之前版本同步,请参阅使用 NaN 配置索引,以避免错误配置问题。

TTL 索引 expireAfterSeconds 值必须介于 02147483647(包含两者)之间。

布尔

可选。一个标志,用于确定是否从查询规划器中隐藏索引。隐藏索引不会作为查询计划选择的一部分进行评估。

默认值为 false

storageEngine

文档

可选。允许用户在创建索引时基于每个索引配置存储引擎。

storageEngine 选项应采用以下形式:

storageEngine: { <storage-engine-name>: <options> }

在复制过程中,对创建索引时指定的存储引擎配置选项进行验证并记录到 oplog 中,以支持包含使用不同存储引擎的成员的副本集。

Parameter
类型
说明

collation

文档

可选。指定索引的排序规则

排序规则允许用户为字符串比较指定特定于语言的规则,例如字母大小写和重音符号规则。

如果在集合级别指定排序规则:

  • 如果创建索引时未指定排序规则,MongoDB 将使用集合的默认排序规则创建索引。

  • 如果您在创建索引时指定了排序规则,MongoDB 将使用指定的排序规则创建索引。

排序规则选项的语法如下:

collation: {
locale: <string>,
caseLevel: <boolean>,
caseFirst: <string>,
strength: <int>,
numericOrdering: <boolean>,
alternate: <string>,
maxVariable: <string>,
backwards: <boolean>
}

指定排序规则时,locale 字段为必填字段;所有其他排序规则字段均为可选字段。有关字段的说明,请参阅排序规则文档

版本 3.4 中的新增功能

以下索引只支持简单的二进制比较,不支持排序规则

提示

要在具有非简单排序规则的集合上创建text2dgeoHaystack索引,您必须在创建索引时显式指定{collation: {locale: "simple"} }

如果在集合级别指定排序规则:

  • 如果创建索引时未指定排序规则,MongoDB 将使用集合的默认排序规则创建索引。

  • 如果您在创建索引时指定了排序规则,MongoDB 将使用指定的排序规则创建索引。

提示

通过指定排序规则 strength12,您可以创建不区分大小写的索引。排序规则 strength1 的索引既不区分变音符号,也不区分大小写。

您可以使用不同的排序规则对同一键创建多个索引。 要创建具有相同键模式但不同排序规则的索引,您必须提供唯一索引名称。

要使用索引进行字符串比较,操作还必须指定相同的排序规则。换言之,如果一个操作对索引字段进行字符串比较,但又设定了与索引字段不同的排序规则,那么这个设有排序规则的索引将无法支持该操作。

警告

由于配置了排序规则的索引是通过 ICU 排序规则键来实现排序,因此,相比未配置排序规则的索引的索引键,有排序规则感知的索引键可能会更大。

例如,集合 myColl 在字符串字段 category 上具有一个索引,排序规则语言环境为 "fr"

db.myColl.createIndex( { category: 1 }, { collation: { locale: "fr" } } )

以下查询操作指定了与索引相同的排序规则,因此可以使用索引:

db.myColl.find( { category: "cafe" } ).collation( { locale: "fr" } )

而以下查询操作默认使用“简易的”二进制排序器,因此无法使用索引:

db.myColl.find( { category: "cafe" } )

如果一个复合索引的前缀键不是字符串、数组和嵌入式文档,在这种情况下,即使查询操作指定了一个与索引不同的排序规则,它仍然可以利用该复合索引来支持对其前缀健的比较。

例如,集合 myColl 在数值字段 scoreprice 以及字符串字段 category 上有一个复合索引;该索引使用排序规则语言环境 "fr" 创建,用于进行字符串比较:

db.myColl.createIndex(
{ score: 1, price: 1, category: 1 },
{ collation: { locale: "fr" } } )

以下操作使用 "simple" 二进制排序规则进行字符串比较,它们可以使用索引:

db.myColl.find( { score: 5 } ).sort( { price: 1 } )
db.myColl.find( { score: 5, price: { $gt: NumberDecimal( "10" ) } } ).sort( { price: 1 } )

以下操作使用 "simple" 二进制排序规则对索引的 category 字段进行字符串比较,它们可以使用索引仅完成查询的 score: 5 部分:

db.myColl.find( { score: 5, category: "cafe" } )

重要

与文档键(包括嵌入式文档键)的匹配使用简单的二进制比较。这意味着类似“foo.bár”的键的查询不会匹配“foo.bar”键,无论您为 strength 参数设置了什么值。

以下选项仅适用于文本索引:

Parameter
类型
说明

weights

文档

可选。对于文本索引,指包含字段和权重对的文档。权重是一个介于 1 到 99,999 之间的整数,表示该字段相对于其他索引字段的得分重要性。您可以为部分或全部索引字段指定权重。请参阅为自管部署上的文本搜索结果分配权重来调整得分。默认值为 1

从 MongoDB 5.0 开始,只有文本索引才允许使用 weights 选项。

default_language

字符串

可选。对于文本索引,确定停止词列表的语言以及词干分析器和分词器的规则。欲了解更多信息和示例,请参阅自管理部署上的文本搜索语言为自管理部署上的文本索引指定默认语言。默认值为 english

language_override

字符串

可选。 对于文本索引,为collection文档中包含文档覆盖语言的字段的名称。默认值为language 。 有关示例,请参阅使用任何字段指定文档的语言

textIndexVersion

整型

可选。text 索引版本号。用户可以使用此选项覆盖默认版本号。

有关可用版本,请参阅版本。

以下选项仅适用于 2dsphere 索引:

Parameter
类型
说明

2dsphereIndexVersion

整型

可选。2dsphere 索引版本号。用户可以使用此选项覆盖默认版本号。

有关可用版本,请参阅版本。

以下选项仅适用于 2d 索引:

Parameter
类型
说明

bits

整型

可选。对于 2d 索引,存储的位置数据的地理哈希值的精度数。

bits 值的范围为 1 到 32(含)。默认值为 26

min

数字

可选。对于 2d 索引,这是经度和纬度值的包含下边界。默认值为 -180.0

max

数字

可选。对于 2d 索引,这是经度和纬度值的包含上边界。默认值为 180.0

以下选项仅适用于geoHaystack索引:

Parameter
类型
说明

bucketSize

数字

对于geoHaystack索引,请指定对位置值进行分组的单位数量;即将彼此在指定单位数内的位置值分组在同一个存储桶中。

该值必须大于 0。

注意

已在 MongoDB 5.0 中删除

MongoDB 5.0 删除了已弃用的geoHaystack索引和geoSearch命令。 请改用带有 的 2d $geoNear索引 或受支持的 地理空间查询操作符 之一。

将 MongoDB 实例升级到 5.0 并将 FeatureCompatibilityVersion 设置为 5.0 会删除所有先前存在的 geoHaystack 索引。

以下选项仅适用于通配符索引:

Parameter
类型
说明

wildcardProjection

文档

可选。允许用户使用 { "$**" : 1} 键模式在通配符索引中包括或排除特定的字段路径。只有在所有文档字段上创建通配符索引时,该选项才有效。如果在特定字段路径及其子字段上创建通配符索引,则无法指定该选项,例如 { "path.to.field.$**" : 1 }

wildcardProjection 选项采用以下形式:

wildcardProjection: {
"path.to.field.a" : <value>,
"path.to.field.b" : <value>
}

<value> 可以是以下任一项:

  • 1true 以将字段包含在通配符索引中。

  • 0false 以将该字段包含在通配符索引中。

默认情况下,通配符索引会省略 _id 字段。要将 _id 字段包含在通配符索引中,必须将其显式包含在 wildcardProjection 文档中:

{
"wildcardProjection" : {
"_id" : 1,
"<field>" : 0|1
}
}

除了显式包含_id字段之外,您不能在wildcardProjection文档中合并包含和排除声明。

版本 4.2 中进行了更改

MongoDB 使用优化的构建过程,在索引构建开始和结束时获取并持有指定集合的独占锁。 对集合的所有后续操作都必须等到createIndex()释放独占锁。 createIndex()允许在索引构建的大部分过程中交替执行读取和写入操作。

有关 createIndex()的锁定行为的更多信息,请参阅在填充集合上构建索引

如果为已存在的索引调用 db.collection.createIndex(),MongoDB 不会重新创建该索引。

排序规则选项外,如果使用一组索引选项创建一个索引,然后尝试使用其他索引选项重新创建同一索引,MongoDB 不会更改选项,也不会重新创建索引。

可以在不删除和重新创建索引的情况下更改隐藏选项。请参阅隐藏选项

要更改其他索引选项,请先使用 db.collection.dropIndex() 删除现有索引,然后使用新选项运行 db.collection.createIndex()

您可以使用不同的排序规则对同一键创建多个索引。 要创建具有相同键模式但不同排序规则的索引,您必须提供唯一索引名称。

要隐藏或取消隐藏现有索引,可使用以下 mongosh 方法:

例如,

  • 要将索引的 hidden 选项更改为 true,请使用 db.collection.hideIndex() 方法:

    db.restaurants.hideIndex( { borough: 1, ratings: 1 } );
  • 要将索引的 hidden 选项更改为 false,请使用 db.collection.unhideIndex() 方法:

    db.restaurants.unhideIndex( { borough: 1, city: 1 } );

提示

另请参阅:

如果事务不是跨分片写事务,则可以在分布式事务中创建集合和索引。

要在事务中使用 db.collection.createIndex(),该事务必须使用读关注 "local"。如果指定 "local" 以外的读关注级别,则该事务将失败。

提示

另请参阅:

以下示例在字段 orderDate 上创建一个升序索引。

db.collection.createIndex( { orderDate: 1 } )

如果 keys 文档指定了超过一个字段,则 createIndex() 将创建一个复合索引。

以下示例在 orderDate 字段(按升序)和 zipcode 字段(按降序)上创建复合索引。

db.collection.createIndex( { orderDate: 1, zipcode: -1 } )

复合索引可以包含单个哈希字段。复合哈希索引需要将 featureCompatibilityVersion 设置为至少 5.0

以下示例对 state 字段(按升序)和 zipcode 字段(哈希)创建复合索引:

db.collection.createIndex( { "state" : 1, "zipcode" : "hashed" } )

复合索引中字段的顺序对于支持使用索引进行 sort() 操作非常重要。

版本 3.4 中的新增功能

以下示例创建一个名为 category_fr 的索引。该示例使用指定区域设置 fr 和比较强度 2排序规则创建索引:

db.collection.createIndex(
{ category: 1 },
{ name: "category_fr", collation: { locale: "fr", strength: 2 } }
)

以下示例使用排序规则创建名为 date_category_fr 的复合索引。该排序规则仅适用于具有字符串值的索引键。

db.collection.createIndex(
{ orderDate: 1, category: 1 },
{ name: "date_category_fr", collation: { locale: "fr", strength: 2 } }
)

排序规则适用于值为字符串的索引键。

对于使用相同排序规则的索引键的查询或排序操作,MongoDB 可以使用索引。有关详细信息,请参阅排序规则和索引使用

4.2 版本中的新增功能

mongod featureCompatibilityVersion必须为4.2才能创建通配符索引。 有关设置 FCV 的说明,请参阅在 MongoDB 5.0 部署上设置特征兼容性版本。

  • 默认情况下,通配符索引会省略 _id 字段。要将 _id 字段包含在通配符索引中,必须将其显式包含在 wildcardProjection 文档中:

    {
    "wildcardProjection" : {
    "_id" : 1,
    "<field>" : 0|1
    }
    }

    除了显式包含_id字段之外,您不能在wildcardProjection文档中合并包含和排除声明。

  • 通配符索引不支持以下索引类型或属性:

    注意

    通配符索引不同于通配符文本索引,并且与通配符文本索引不兼容。通配符索引不支持使用 $text 操作符的查询。

    有关通配符索引限制的完整文档,请参阅通配符索引限制。

有关“通配符索引”的完整文档,请参阅“通配符索引”。

下面列出了创建通配符索引的示例:

以某一 products_catalog 集合为例,其中的文档可能包含 product_attributes 字段。product_attributes 字段可包含任意嵌套字段,其中包括嵌入式文档文档和数组:

db.products_catalog.insertMany( [
{
_id : ObjectId("5c1d358bf383fbee028aea0b"),
product_name: "Blaster Gauntlet",
product_attributes: {
price: {
cost: 299.99,
currency: "USD"
}
}
},
{
_id: ObjectId("5c1d358bf383fbee028aea0c"),
product_name: "Super Suit",
product_attributes: {
superFlight: true,
resistance: [ "Bludgeoning", "Piercing", "Slashing" ]
}
}
] )

以下操作在 product_attributes 字段上创建一个通配符索引:

use inventory
db.products_catalog.createIndex( { "product_attributes.$**" : 1 } )

通过此通配符索引,MongoDB 可以对 product_attributes 的所有标量值建立索引。如果字段是嵌套文档或数组,则通配符索引将递归到文档/数组中,并为文档/数组中的所有标量字段建立索引。

通配符索引可以支持对 product_attributes 或其嵌套字段之一进行任意单字段查询:

db.products_catalog.find( { "product_attributes.superFlight" : true } )
db.products_catalog.find( { "product_attributes.maxSpeed" : { $gt : 20 } } )
db.products_catalog.find( { "product_attributes.elements" : { $eq: "water" } } )

注意

特定于路径的通配符索引语法与 wildcardProjection 选项不兼容。有关更多信息,请参阅参数文档

以某一 products_catalog 集合为例,其中的文档可能包含 product_attributes 字段。product_attributes 字段可包含任意嵌套字段,其中包括嵌入式文档文档和数组:

db.products_catalog.insertMany( [
{
_id : ObjectId("5c1d358bf383fbee028aea0b"),
product_name: "Blaster Gauntlet",
product_attributes: {
price: {
cost: 299.99,
currency: "USD"
}
}
},
{
_id: ObjectId("5c1d358bf383fbee028aea0c"),
product_name: "Super Suit",
product_attributes: {
superFlight: true,
resistance: [ "Bludgeoning", "Piercing", "Slashing" ]
}
}
] )

以下操作对所有标量字段(不包括 _id 字段)创建通配符索引:

use inventory
db.products_catalog.createIndex( { "$**" : 1 } )

通过此通配符索引,MongoDB 可为集合中每个文档的所有标量字段建立索引。如果给定字段是嵌套文档或数组,则通配符索引将递归到文档/数组中并对文档/数组中的所有标量字段构建索引。

创建的索引可以支持对集合中文档内任意字段的查询:

db.products_catalog.find( { "product_price" : { $lt : 25 } } )
db.products_catalog.find( { "product_attributes.elements" : { $eq: "water" } } )

注意

默认情况下,通配符索引会省略 _id 字段。要将 _id 字段包含在通配符索引中,则必须将其明确包含在wildcardProjection文档中。查看参数文档以获取更多信息。

以某一 products_catalog 集合为例,其中的文档可能包含 product_attributes 字段。product_attributes 字段可包含任意嵌套字段,其中包括嵌入式文档文档和数组:

db.products_catalog.insertMany( [
{
_id : ObjectId("5c1d358bf383fbee028aea0b"),
product_name: "Blaster Gauntlet",
product_attributes: {
price: {
cost: 299.99,
currency: "USD"
}
}
},
{
_id: ObjectId("5c1d358bf383fbee028aea0c"),
product_name: "Super Suit",
product_attributes: {
superFlight: true,
resistance: [ "Bludgeoning", "Piercing", "Slashing" ]
}
}
] )

以下操作创建通配符索引并使用wildcardProjection选项,以仅在索引中包含product_attributes.elementsproduct_attributes.resistance字段的标量值。

use inventory
db.products_catalog.createIndex(
{ "$**" : 1 },
{
"wildcardProjection" : {
"product_attributes.elements" : 1,
"product_attributes.resistance" : 1
}
}
)

虽然键模式"$**"涵盖了文档中的所有字段,但wildcardProjection字段将索引限制为仅包含所包含的字段。 有关wildcardProjection的完整文档,请参阅wildcard索引的选项。

如果字段是嵌套文档或数组,则通配符索引将递归到文档/数组中并对文档/数组中的所有标量字段构建索引。

创建的索引可支持对 wildcardProjection 中包含的任何标量字段查询:

db.products_catalog.find( { "product_attributes.elements" : { $eq: "Water" } } )
db.products_catalog.find( { "product_attributes.resistance" : "Bludgeoning" } )

注意

通配符索引不支持在 wildcardProjection 文档中混用包含和排除语句,除非显示包含 _id 字段时。有关 wildcardProjection 的更多信息,请参阅参数文档

以某一 products_catalog 集合为例,其中的文档可能包含 product_attributes 字段。product_attributes 字段可包含任意嵌套字段,其中包括嵌入式文档文档和数组:

db.products_catalog.insertMany( [
{
_id : ObjectId("5c1d358bf383fbee028aea0b"),
product_name: "Blaster Gauntlet",
product_attributes: {
price: {
cost: 299.99,
currency: "USD"
}
}
},
{
_id: ObjectId("5c1d358bf383fbee028aea0c"),
product_name: "Super Suit",
product_attributes: {
superFlight: true,
resistance: [ "Bludgeoning", "Piercing", "Slashing" ]
}
}
] )

以下操作可创建通配符索引,并使用 wildcardProjection 文档对集合中每个文档的所有标量字段进行索引,不包括 product_attributes.elementsproduct_attributes.resistance 字段:

use inventory
db.products_catalog.createIndex(
{ "$**" : 1 },
{
"wildcardProjection" : {
"product_attributes.elements" : 0,
"product_attributes.resistance" : 0
}
}
)

键模式"$**"涵盖了文档中的所有字段,而wildcardProjection字段则从索引中排除了指定字段。 有关wildcardProjection的完整文档,请参阅wildcard索引的选项。

如果字段是嵌套文档或数组,则通配符索引将递归到文档/数组中并对文档/数组中的所有标量字段构建索引。

创建的索引可以支持对任何标量字段的查询,但 wildcardProjection 排除的字段除外

db.products_catalog.find( { "product_attributes.maxSpeed" : { $gt: 25 } } )
db.products_catalog.find( { "product_attributes.superStrength" : true } )

注意

通配符索引不支持在 wildcardProjection 文档中混用包含和排除语句,除非显示包含 _id 字段时。有关 wildcardProjection 的更多信息,请参阅参数文档

注意

需要 featureCompatibilityVersion 4.4+

副本集或分片集群中的每个 mongod 必须featureCompatibilityVersion 设置为至少 4.4,才能跨副本集节点同时启动索引构建。

索引构建在副本集或分片集群上,并在所有数据承载副本集成员上同时构建。对于分片集群,索引构建仅会在包含当前被索引集合的数据的分片上进行。主节点需要最少数量的数据承载 voting 节点(即提交法定节点数),包括其自身,这些节点必须在将索引标记为可供使用之前完成构建。 有关详细信息,请参阅复制环境中的索引构建

为 操作指定createIndex() commitQuorum 参数,以设置承载数据的投票节点(即提交法定节点数)(包括主节点)的最小数量,主节点必须在主节点将索引标记为就绪之前完成索引构建。默认提交法定人数为votingMembers ,或所有承载数据的投票副本集节点。

以下操作创建了提交法定人数"majority" 的索引,或简单多数的数据承载投票成员:

db.getSiblingDB("examples").invoices.createIndex(
{ "invoices" : 1 },
{ },
"majority"
)

仅在简单多数承载数据的投票成员“投票”提交索引构建后,主节点才会将索引构建标记为准备就绪。有关索引构建和投票过程的更多信息,请参阅复制环境中的索引构建

后退

db.collection.countDocuments