Filtrage des champs dans les documents MongoDB avec le pilote mongo-go-driver
L'une des fonctionnalités clés des requêtes MongoDB est la possibilité de filtrer les champs renvoyé dans les résultats de la requête. C'est ce qu'on appelle projection de champ.
Requête avec projection de champ
Le pilote mongo-go-driver propose plusieurs options pour spécifier des projections de champ. Une option consiste à utiliser la fonction findopt.Projection. Cependant, comme vous l'avez constaté, cette approche peut échouer si les noms de champs dans la structure de projection ne sont pas exportés. Pour résoudre ce problème, vous pouvez utiliser les stratégies suivantes :
Méthode 1 : Utiliser les noms de champs exportés
L'approche la plus simple consiste à utiliser les noms de champs exportés (c'est-à-dire, champs commençant par des lettres majuscules) dans votre structure de projection. Cela garantit que les noms de champs sont accessibles au pilote mongo-go-driver.
type Fields struct { ID int `bson:"_id"` } projection := Fields{ ID: 0, }
Méthode 2 : utiliser les balises Struct
Vous pouvez également utiliser des balises struct pour mapper les noms de champs non exportés au champ MongoDB correspondant noms.
type Fields struct { _id int `bson:"_id"` } projection := Fields{ _id: 0, }
Utilisation de la projection dans la requête
Une fois que vous avez défini la projection, vous pouvez l'utiliser dans les méthodes FindOne ou Find en définissant SetProjection option.
filter := bson.NewDocument(bson.EC.ObjectID("_id", starterId)) result := staCon.collection.FindOne(nil, filter, options.FindOne().SetProjection(projection)).Decode(s)
Exemple d'utilisation bson.M
À partir d'une version ultérieure du pilote mongo-go-driver, vous pouvez également spécifier la projection à l'aide d'une simple carte bson.M.
options.FindOne().SetProjection(bson.M{"_id": 0})
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!