Docs Menu
Docs Home
/ /

MongoDB Search クエリの実行

このガイドでは、 Goドライバーを使用してコレクションに対して MongoDB Search クエリを実行する方法を学習できます。 MongoDB Search を使用すると、 MongoDB Atlasでホストされているコレクションに対して全文検索を実行できます。 MongoDB Search インデックスは、検索の動作とインデックスを作成するフィールド を指定します。

このガイドの例では、Atlasサンプルデータセットの moviesデータベース内のsample_mflix コレクションを使用します。 MongoDB Atlasクラスターを無料で作成して、サンプルデータセットをロードする方法については、次のMongoDBスタートガイド( https://www.mongodb.com/ja-jp/docs/get-started/?) を参照してください。言語=goガイド。

このセクションでは、 コレクションに対してMongoDB Search クエリを実行するための集計パイプラインを作成する方法について説明します。

MongoDB Search クエリを実行するには、コレクションにMongoDB Searchインデックスを作成する必要があります。 MongoDB Searchインデックス をプログラムで作成する方法については、 インデックスガイドの MongoDB Search とMongoDB ベクトル検索インデックスのセクションを参照してください。

MongoDB Searchインデックスを作成したら、パイプラインステージの配列に $search ステージを追加して、検索条件を指定します。次に、Aggregate() メソッドを呼び出し、パイプライン配列をパラメーターとして渡します。

Tip

集計操作の詳細については、集計ガイドを参照してください。

この例では、次のアクションを実行してMongoDB Search クエリを実行します。

  • ドライバーに指示する $search ステージを作成し、titleフィールドに "Alabama" という単語が含まれるドキュメントを検索します。

  • クエリ結果に title フィールドを含めるようにドライバーに指示する $project ステージを作成します

  • パイプラインのステージをAggregate()メソッドに渡し、結果を出力します。

// Defines the pipeline
searchStage := bson.D{{"$search", bson.D{
{"text", bson.D{
{"path", "title"},
{"query", "Alabama"},
}},
}}}
projectStage := bson.D{{"$project", bson.D{{"title", 1}}}}
// Runs the pipeline
cursor, err := collection.Aggregate(ctx, mongo.Pipeline{searchStage, projectStage})
if err != nil {
panic(err)
}
// Prints the results
var results []bson.D
if err = cursor.All(ctx, &results); err != nil {
panic(err)
}
for _, result := range results {
fmt.Println(result)
}
{
_id: new ObjectId('...'),
title: 'Alabama Moon'
}
{
_id: new ObjectId('...'),
title: 'Crazy in Alabama'
}
{
_id: new ObjectId('...'),
title: 'Sweet Home Alabama'
}

MongoDB Search の詳細については、Atlas ドキュメントのMongoDB Search ガイド および $searchパイプラインステージ参照を参照してください。

Aggregate() メソッドの詳細については、API ドキュメントをご覧ください。

戻る

時系列

項目一覧