Mongo データベースでは、「_id」フィールドとして知られる一意の識別子によって特定のドキュメントを検索するのが一般的なタスクです。ここでは、Go 用の人気の MongoDB ドライバーである mgo を使用してこれを実現する方法に関する包括的なガイドを示します。
FindId() メソッドは、ドキュメント ベースのドキュメントをフェッチするように特別に設計されています。 「_id」フィールドに。これは、bson.ObjectId 型の引数、または ObjectId を表す文字列を受け取ります。ただし、FindId() メソッドを使用する場合は、bson.M{} マップ全体を引数として指定するのではなく、ObjectId 値のみを指定する必要があることに注意することが重要です。
コード内での問題は、FindId() メソッドの誤った使用にあります。動作するはずの修正コードは次のとおりです:
err2 := c.FindId(bson.ObjectIdHex("58593d1d6aace357b32bb3a1")).One(&data)
または、Find() メソッドを使用して、bson.M{} マップの「_id」フィールドと値を指定することもできます:
err2 := c.Find(bson.M{"_id": bson.ObjectIdHex("58593d1d6aace357b32bb3a1")}). One(&data)
ドキュメントが見つかった場合、実行中にエラーは発生しません。コード。ただし、コードが依然として data.IdCookie に対して 0 の値を返す場合は、データベース内の ID のフィールド名が、構造体で指定したものと異なることを示唆しています。
Go 構造体と MongoDB ドキュメント間の適切なマッピングを確保するには、struct タグを使用する必要があります。たとえば、データベースの "_id" フィールドの名前が "myid" である場合、次のように構造体にマップできます。
type id_cookie struct { IdCookie int `bson:"myid"` }
パフォーマンスを向上させるには、クエリごとに MongoDB サーバーへの複数の接続を避けることを検討する必要があります。単一のセッションを確立し、それを複数のクエリに再利用すると、操作が大幅に高速化されます。接続処理の最適化の詳細については、[mgo - クエリのパフォーマンスが一貫して遅い (500 ~ 650 ミリ秒)](https://github.com/mongodb/mongo-go-driver/issues/1028)
を参照してください。以上がmgo の FindId() メソッドを使用して ID によって MongoDB ドキュメントを効率的に取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。