MongoDB 検索インデックスを作成するときに、次の方法を使用してインデックスを作成するフィールドを指定できます。
動的マッピング: MongoDB 検索する を有効にして、デフォルトまたは構成されたフィールドタイプのセットに基づいてすべてのフィールドを自動的にインデックス(
typeSet)。静的マッピング:インデックスを作成するフィールドを指定できるようにします。
データ型の制限事項
デフォルトでは、MongoDB 検索するは、レプリカセットまたは単一のシャード上の2.1億インデックスオブジェクトを超えるインデックスの変更のレプリケーションを停止します。ここでは、インデックス作成されたドキュメントまたはネストされた
embeddedDocumentはそれぞれ1つのオブジェクトとしてカウントされます。つまり、インデックスは引き続きクエリ可能ですが、古い結果が生じる可能性があります。If you plan to index fields that might exceed 2.1 billion objects, where an index object is a top-level document or an embedded document, use the numPartitions index option to partition your index (supported only on Search Nodes deployment) or shard your cluster.
フィールド名の先頭にドル記号(
$)が含まれるフィールドにはインデックスを付けられません。オートコンプリートフィールド型は大規模なインデックスを作成する可能性があり、他のフィールド型よりも構築に時間がかかります。カスタム
typeSet定義に含めることで、動的マッピングでautocomplete型を使用できますが、意図しないパフォーマンス、ストレージ、スコアリングへの影響を避けるために、静的マッピングでのみautocomplete型を使用することをお勧めします。詳細については、「オートコンプリート用にフィールドをインデックスする方法」と「MongoDB検索インデックスのパフォーマンス」を参照してください。
構文
次の構文は、MongoDB 検索を有効にして、動的マッピングと静的マッピングを使用してフィールドをインデックス化する方法を示しています。動的マッピングと静的マッピングの詳細については、「動的マッピングと静的マッピング」を参照してください。
1 { 2 "mappings": { 3 "dynamic": true|false | { 4 "typeSet": "<typeset-name>" 5 }, 6 "fields": { 7 "<field-name>": { 8 "type": "<field-type>", 9 ... 10 }, 11 ... 12 } 13 }, 14 "typeSets": [ 15 { 16 "name": "<typeset-name>", 17 "types": [ 18 { 19 "type": "<field-type>", 20 ... 21 }, 22 ... 23 ] 24 }, 25 ... 26 ] 27 }
動的マッピングと静的マッピング
MongoDB Search は、次のコマンドを使用して構成できます。
デフォルトまたは構成されたタイプのセットに基づいてフィールドを自動的にインデックスための 動的マッピング (
typeSet)インデックスされたフィールドのみへの静的マッピング
静的マッピングと動的マッピングを使用することもできます。静的マッピングは、動的マッピング構成を上書きします。
ダイナミックマッピング
MongoDB Search の動的マッピングを使用すると、データ内のフィールドに自動的かつ再帰的にインデックスを付けられるように MongoDB Search を構成できます。フィールドは、デフォルトのタイプセットに基づいて、または typeSet を構成することでインデックス化できます。
動的マッピングを有効または構成できます。
ドキュメント全体に適用するルート
mappingsレベル。[推奨] 指定されたオブジェクトに適用する
documentフィールドタイプ内で。[推奨] フィールドタイプは、要素単位のクエリ比較を必要とするオブジェクトの指定された配列に適用するために、
embeddedDocumentsフィールドタイプ内で使用します($elemMatchと同様)。
注意
ベストプラクティス
動的マッピングでは、多数の一意のフィールドのインデックスの作成が行われるため、占有するディスク容量が多くなり、パフォーマンスが低下する可能性があります。定期的に変更されるフィールドや不明なフィールドのインデックスが必要な場合にのみ、動的マッピングを使用してください。動的マッピングは、親ドキュメントレベルではなく、常にドキュメント内で使用してください。
動的マッピング を使用してデータをインデックスする場合、
MongoDB Search は、データ内の
documentオブジェクト内のtypeSetによってサポートされているすべてのネストされたフィールドも動的にインデックス化します。フィールドに多形データが含まれている場合、MongoDB 検索するは、インデックスで使用される
typeSetでサポートされているすべての型としてフィールドを自動的にインデックス化します。フィールドにtypeSetでサポートされていない型のデータが含まれている場合、 MongoDB Search はそのデータのインデックスしません。
デフォルトを有効 typeSet
MongoDB 検索するでは、dynamic が true に設定されている場合、デフォルトのtypeSet が使用されます。デフォルトのtypeSet では、MongoDB Search は BSON型をMongoDB Searchフィールド型としてインデックス化します。次の表は、デフォルトの を使用する場合にMongoDB 検索するがMongoDB 検索するフィールドタイプとして自動的にインデックスを作成するBSONタイプを示しています。typeSetMongoDB Search は、配列とオブジェクトに含まれている場合は、次のBSON型も自動的にインデックス化します。
BSON Type | MongoDB Search フィールド タイプ |
|---|---|
ブール値 | |
日付 | |
Double、32ビット整数、64ビット整数 | |
ObjectId | |
文字列 | |
UUID | |
null |
以下は、動的マッピングでデフォルトのタイプセットを有効にするための構文です。
1 { 2 "mappings": { 3 "dynamic": true 4 } 5 }
デフォルトのtypeSet を使用してすべてのフィールドにインデックスを作成するインデックス例については、動的マッピングの例 を参照してください。
configurea typeSet
MongoDB Search フィールド型に動的にインデックスを設定するために typeSet を構成します。document、embeddedDocuments、vector、または非推奨のフィールド型を除く任意の BSON 型を、MongoDB Search フィールド型として自動的にインデックス付けするように構成できます。
typeSet の構文は次のとおりです。
注意
Atlas UI Visual Editor から typeSet を構成することはできません。代わりに、Atlas UI JSON Editor を使用してください。
1 { 2 "mappings": { 3 "dynamic": { 4 "typeSet": "<typeset-name>" 5 }, 6 "fields": { 7 "<field-name>": { 8 "type": "<field-type>", 9 ... 10 }, 11 ... 12 } 13 }, 14 "typeSets": [ 15 { 16 "name": "<typeset-name>", 17 "types": [ 18 { 19 "type": "<field-type>" 20 }, 21 ... 22 ] 23 }, 24 ... 25 ] 26 }
typeSet を設定する前に、以下の点を考慮してください。
同じ
typeSetオブジェクト内で、同じフィールドタイプを複数回定義することはできません。各フィールド型に対して 1 つのtypeSet定義のみを構成できます。例、同じ
typeSet定義内でnumberタイプに複数の構成を定義することはできません。multiアナライザを使用して動的マッピングを構成できます。
カスタム typeSet 構成の使用を示すインデックスの例については、動的マッピングの例 を参照してください。
静的マッピング
静的マッピングを使用して、動的にインデックスを作成 したくない フィールドのインデックスオプションを設定したり、1 つのフィールドをインデックス内の他のフィールドと独立して構成したりします。静的マッピングを使用する場合、 MongoDB Search は mappings.fields で指定したフィールドのみをインデックス化します。静的マッピングを使用して、インデックスの作成からフィールドを除外することもできます。
静的マッピングを使用して一部のフィールドのみのインデックスオプションを構成するには、mappings.dynamic を false に設定し、インデックスを作成するフィールドごとにフィールド名、データ型 などの構成オプションを指定します。任意の順序でフィールドを指定できます。
mappings.dynamic フィールドを省略すると、デフォルトで false になります。
1 { 2 "mappings": { 3 "dynamic": true|false, 4 "fields": { 5 "<field-name>": { 6 "type": "<field-type>", 7 ... 8 }, 9 ... 10 } 11 } 12 }
ネストされたフィールドのインデックスを定義するには、そのネストされたフィールドの各親フィールドのマッピングを定義する必要があります。ドット表記を使用してネストされたフィールドを静的にインデックスことはできません。例については、以下の 例 または 組み合わせマッピングの例 を参照してください。
静的マッピングを使用して、フィールドを複数のタイプとしてインデックスできます。フィールドを複数のタイプとしてインデックスには、フィールドのフィールド定義配列でタイプを定義します。静的マッピングを使用して、サポートされているタイプとして任意のフィールドをインデックスできます。詳しくは、 MongoDB 検索フィールド タイプ を参照してください。
次の例では、フィールドを複数のタイプとしてインデックスを作成するためのフィールド定義を示しています。
1 { 2 "mappings": { 3 "dynamic": true|false | { 4 "typeSet": "<type-set-name>" 5 }, 6 "fields": { 7 "<field-name>": [ 8 { 9 "type": "<field-type>", 10 ... 11 }, 12 { 13 "type": "<field-type>", 14 ... 15 }, 16 ... 17 ], 18 ... 19 } 20 }. 21 "typeSets": [ 22 { 23 "name": "<typeset-name>", 24 "types": [ 25 { 26 "type": "<field-type>" 27 }, 28 ... 29 ] 30 }, 31 ... 32 ] 33 }
静的マッピングを示すその他のインデックス例については、静的マッピングの例を参照してください。
MongoDB 検索する フィールド タイプ
MongoDB Search は次のBSONデータ型をサポートしていません。
Decimal128
JavaScript コード(スコープ付き)
Max key
Min key
正規表現
タイムスタンプ
MongoDB Search は、mongot に string 型のフィールドを自動的に保存します。インデックス定義で [ MongoDB Search インデックスに保存されたソース フィールドを定義する ] オプションを使用して、サポートされているすべての データ型 のフィールドをMongoDB Search に保存できます。mongot とMongoDB Searchノードのアーキテクチャの詳細については、 MongoDB Search 配置オプション を参照してください。
次の表は、サポートされているBSONデータ型 と、 BSONデータ型のインデックスに使用できるMongoDB Searchフィールド型 を示しています。以下の表では、フィールド値をクエリするために使用できる 演算子 と コレクター も確認できます。
BSON 型 | MongoDB Search フィールド タイプ | 演算子とコレクター |
|---|---|---|
配列内のデータ型をサポートする演算子。 | ||
ブール値 | ||
日付 | ||
日付 | ||
Double | ||
Double | ||
Double | ||
32 ビット整数 | ||
32 ビット整数 | ||
64 ビット整数 | ||
64 ビット整数 | ||
null | 該当なし | |
オブジェクト | オブジェクト内のフィールド型をサポートする演算子。 | |
オブジェクト | 埋め込みドキュメント(オブジェクトの配列用) | |
ObjectId | ||
文字列 | ||
文字列 | ||
文字列 | ||
文字列 | ||
ベクトル |
これらの演算子は文字列の配列をサポートしていません。
MongoDB Search は、静的にインデックスが付けられたフィールドと動的にインデックスが付けられたフィールドの両方の null 値を自動的にインデックス化するため、 MongoDB Search には null 値をインデックス化するためのフィールドタイプが含まれていません。
非推奨。非推奨のファセットフィールド型とその更新された対応タイプの詳細については、ファセットのフィールド型の比較を参照してください。
double または int の配列。
例
The following sample index definitions on the sample_mflix.movies collection demonstrate how to index fields using dynamic and static mappings. You can load the sample data on your cluster to try the examples. To learn more about how to create MongoDB Search indexes, see MongoDB Search Quick Start.
ダイナミックマッピングの例
次のサンプルインデックス定義は、動的マッピングの使用方法を示しています。
次のインデックス定義。
ルートレベルでの動的マッピングを有効にし、
only_stringsという名前のtypeSet定義に基づいてコレクション内のフィールドを自動的にインデックスます。これにより、positionsインデックスオプションを使用し、storeをfalseに設定します。 。これらの構成オプションでは、クエリ強調表示用にフィールド値またはタームオフセットを保存しないため、ディスク領域が節約されます。
{ "mappings": { "dynamic": { "typeSet": "only_strings" } }, "typeSets": [ { "name": "only_strings", "types": [ { "type": "string", "store": false, "indexOptions": "positions" } ] } ] }
次のインデックス定義。
ルートレベルでの動的マッピングを有効にし、
only_stringsという名前のtypeSetに基づいてコレクション内のフィールドを動的にインデックス。これにより、positionsインデックスオプションとstoreがfalseに設定され、コレクション内の string フィールドにインデックスが作成されます。クエリ強調表示用のフィールド値またはタームオフセットを保存しないため、ディスク領域が節約されます。awardsフィールドをdocumentタイプとしてインデックス化し、only_numberstypeSetとdynamicオプションを併用して、awardsドキュメントの数値サブフィールドのみを動的にインデックスます。つまり、数値サブフィールドwinsとnominationsはインデックス付きですが、string サブフィールドtextはインデックス化されていません。
{ "mappings": { "dynamic": { "typeSet": "only_strings" }, "fields": { "awards": { "type": "document", "dynamic": { "typeSet": "only_numbers" } } } }, "typeSets": [ { "name": "only_numbers", "types": [ { "type": "number" } ] }, { "name": "only_strings", "types": [ { "type": "string", "store": false, "indexOptions": "positions" } ] } ] }
次のインデックス定義。
以下の動作を指定する
indexedTypesという名前のtypeSetを使用して、特定のフィールドタイプの動的マッピングを構成します。string フィールドを
tokenタイプとして自動的にインデックス。数値フィールドを
numberタイプとして自動的にインデックス。
plotフィールドをインデックス作成から除外します。
{ "mappings": { "dynamic": { "typeSet": "indexedTypes" }, "fields": { "plot": [] } }, "typeSets": [ { "name": "indexedTypes", "types": [ { "type": "token" }, { "type": "number" } ] } ] }
静的マッピングの例
次のサンプルインデックス定義は、静的マッピングを使用する方法を示しています。
次のインデックス定義。
ルート レベルで静的フィールドマッピングを指定します(
dynamic:false)。つまり、mappings.fieldsで指定されていないフィールドにはインデックスが付けられません。インデックス定義には、インデックスの作成用の次のフィールドが明示的に含まれています。タイプ
documentであるawardsフィールド。埋め込まれたサブフィールドには、wins、nominations、textの 3 つがあります。winsとnominationsのサブフィールドには数値データが含まれており、number型としてインデックス付けされています。nominationsはint64表現でインデックス付けされているため、デフォルトのnumber型よりも大きい整数値をサポートできます。textサブフィールドには string データが含まれており、英語のテキストに最適化された lucene.english アナライザ を使用してstring型としてインデックス付けされます。また、textフィールドではignoreAboveオプションを使用して、長さが 255 文字を超える文字列を無視します。string データを含む
titleフィールドは、製品名やタイトルなどの多くの空白を含むテキストに最適化されている lucene.whitespace アナライザ を使用してタイプstringとしてインデックス付けされます。titleフィールドはマルチオプションを使用してlucene.frenchアナライザをセカンダリアナライザとして指定します。これにより、$searchクエリでpathとして{ "value": "title", "multi": "frenchAnalyzer" }を指定し、フランス語のクエリ用語をよりターゲットにできます。文字列の配列を含み、タイプ
stringとしてインデックス付けされるgenresフィールド。MongoDB Search は、デフォルトで lucene.standard アナライザを使用して配列要素をインデックス化します。配列のインデックスの作成において、 MongoDB Search では配列要素のデータ型のみが必要です。インデックス定義でデータが配列に含まれていることを指定する必要はありません。
{ "mappings": { "dynamic": false, "fields": { "awards": { "type": "document", "fields": { "wins": { "type": "number" }, "nominations": { "type": "number", "representation": "int64" }, "text": { "type": "string", "analyzer": "lucene.english", "ignoreAbove": 255 } } }, "title": { "type": "string", "analyzer": "lucene.whitespace", "multi": { "frenchAnalyzer": { "type": "string", "analyzer": "lucene.french" } } }, "genres": { "type": "string" } } } }
複合マッピングの例
次のインデックス定義例では、動的マッピングと静的マッピングを組み合わせています。
このインデックス定義:
静的フィールドマッピングを指定します(
dynamic:false)。つまり、明示的に指定されていないフィールドとフィールド型はインデックス化されません。したがって、インデックス定義には次のものが含まれます。titlestring データを含むstringフィールドは、製品名やタイトルなど、多くの空白を含むテキストに最適化されている lucene.whitespaceアナライザ を使用して タイプとしてインデックス付けされます。タイプ
documentで、3 つのサブフィールドを含むawardsフィールド。winsとnominationsサブフィールドには数値データが含まれ、textサブフィールドには string データが含まれています。ドキュメント内のネストされた各フィールドのデータ型を明示的に設定する代わりに、インデックス定義により、ドキュメント内のすべてのサブフィールドの動的なマッピングが可能になります。これにより、winsとnominationsはnumberタイプとして、textはstringタイプとしてインデックス化されます。textフィールドのデータは、デフォルトでlucene.standardアナライザを使用してインデックス化されます。
{ "mappings": { "dynamic": false, "fields": { "title": { "type": "string", "analyzer": "lucene.whitespace" }, "awards": { "type": "document", "dynamic": true } } } }
このインデックス定義:
ルート レベルで静的フィールドマッピングを指定します(
dynamic:false)。つまり、mappings.fieldsオプションで指定されていないフィールドにはインデックスが付けられません。movieAwardsという名前のカスタムtypeSetを使用して、documentタイプであるawardsフィールドの動的マッピングを定義します。awardsフィールドには、wins、nominations、textの 3 つのサブフィールドが埋め込まれています。ルートレベルでdynamicをtrueに設定してサブフィールドを自動的にインデックスの作成するか、静的マッピングを使用してネストされた各フィールドを明示的にインデックスの作成することで、サブフィールドを自動的にインデックスの作成する代わりに、インデックス定義はtypeSetを使用してdocumentフィールドタイプの動的マッピングを構成しますmovieAwardsという名前の定義。movieAwardstypeSetは次の処理を行います。マルチオプションを使用して複数のアナライザを指定し、string フィールドを
stringタイプとしてインデックスします。multiオプションを使用して:lucene.englishとlucene.frenchnumber型のデフォルト設定を使用して、数値フィールドをnumberとしてインデックスします。{ "mappings": { "dynamic": false, "fields": { "awards": { "type": "document", "dynamic": { "typeSet": "movieAwards" } } } }, "typeSets": [ { "name": "movieAwards", "types": [ { "type": "string", "multi": { "english": { "type": "string", "analyzer": "lucene.english" }, "french": { "type": "string", "analyzer": "lucene.french" } } }, { "type": "number" } ] } ] }