Overview
このガイドでは、MongoDB Kotlin ドライバー で ビルダ を使用して インデックス を指定する方法を学びます。「 Indexes
ビルダには、次のタイプのインデックスを構築するためのヘルパー メソッドが用意されています。
インデックスは、コレクションのデータセットのサブセットを保存します。 インデックスには、特定のフィールドまたはフィールド セットの値が、フィールド値の順に保存されます。 インデックスによってカバーされるクエリの例については、「インデックスに関するガイド 」をご覧ください。
Indexes
クラスは、すべてのMongoDBインデックスタイプの静的ファクトリー メソッドを提供します。各メソッドはBSONインスタンスを返します。これを createIndex()に渡すことができます。
Tip
簡潔にするために、 インデックスクラスのすべてのメソッドをインポートすることを選択できます。
import com.mongodb.client.model.Indexes.*
昇順インデックス
昇順インデックスを使用すると、インデックス フィールドの値でクエリ結果を最小から最大の順にソートできます。
昇順のインデックスを作成するには、まず昇順()ビルダー Bson
メソッドを呼び出して、インデックスを作成するフィールドの名前を渡して、インデックスドキュメントを表す インスタンスを作成します。次に、インデックスドキュメントを含む Bson
インスタンスを渡して、コレクションの createIndex()
メソッドを呼び出します。
注意
1 つのフィールドに昇順または降順のインデックスがある場合、MongoDB はどちらの方向のインデックスも使用してソートできます。
次の例では、 name
フィールドに昇順のインデックスを指定しています。
val ascendingIndex = Indexes.ascending("name") val indexName = collection.createIndex(ascendingIndex) println(indexName)
name_1
降順インデックス
降順インデックスを使用すると、インデックス フィールドの値でクエリ結果を最大から最小の順にソートできます。
降順インデックスを作成するには、まず降順() ビルダーBson
メソッドを呼び出して、インデックスを作成するフィールドの名前を渡して、インデックスドキュメントを表す インスタンスを作成します。次に、インデックスドキュメントを含む Bson
インスタンスを渡して、コレクションの createIndex()
メソッドを呼び出します。
次の例では、 capacity
フィールドに降順のインデックスを指定しています。
val descendingIndex = Indexes.descending("capacity") val indexName = collection.createIndex(descendingIndex) println(indexName)
capacity_-1
複合インデックス
複合インデックスを作成するには、まず compoundIndex() ビルダーBson
メソッドを呼び出して、インデックスを作成するフィールドの名前を渡して、インデックスドキュメントを表す インスタンスを作成します。次に、インデックスドキュメントを含む Bson
インスタンスを渡して、コレクションの createIndex()
メソッドを呼び出します。
次の例では、 capacity
とyear
フィールドに降順インデックス、その後にname
フィールドの昇順インデックスで構成される複合インデックスを指定しています。
val compoundIndexExample = Indexes.compoundIndex( Indexes.descending("capacity", "year"), Indexes.ascending("name") ) val indexName = collection.createIndex(compoundIndexExample) println(indexName)
capacity_-1_year_-1_name_1
Text Indexes
テキスト インデックスでは、インデックス付きフィールドのテキストでドキュメントがグループ化されます。
テキストインデックスを作成するには、まず text() ビルダ メソッドを呼び出して、インデックスするフィールドの名前を渡して、インデックスドキュメントを表す Bson
インスタンスを作成します。次に、インデックスドキュメントを含む Bson
インスタンスを渡して、コレクションの createIndex()
メソッドを呼び出します。
次の例えでは、 theaters
フィールドに テキスト インデックス キーを指定します。
val textIndex = Indexes.text("theaters") val indexName = collection.createIndex(textIndex) println(indexName)
theaters_text
ハッシュされたインデックス
ハッシュされたインデックスは、インデックス フィールドのハッシュ値でドキュメントをグループ化します。
ハッシュされたインデックスを作成するには、まずハッシュされた() ビルダ Bson
メソッドを呼び出して、インデックスドキュメントを表す インスタンスを作成し、インデックスするフィールドの名前を渡します。次に、インデックスドキュメントを含む Bson
インスタンスを渡して、コレクションの createIndex()
メソッドを呼び出します。
次の例えでは、 capacity
フィールドに ハッシュされたインデックスを指定します。
val hashedIndex = Indexes.hashed("capacity") val indexName = collection.createIndex(hashedIndex) println(indexName)
capacity_hashed
地理空間インデックス
2dsphere
インデックスは、インデックス フィールドの座標でドキュメントをグループ化します。
2dsphere
インデックスを作成するには、まず geo2dsphere() ビルダー メソッドを呼び出して、インデックスドキュメントを表す Bson
インスタンスを作成し、インデックスするフィールドの名前を渡します。次に、インデックスドキュメントを含む Bson
インスタンスを渡して、コレクションの createIndex()
メソッドを呼び出します。
次の例えでは、 location
フィールドに2dsphere
インデックスを指定します。
val geo2dsphereIndex = Indexes.geo2dsphere("location") val indexName = collection.createIndex(geo2dsphereIndex) println(indexName)
location_2dsphere