Maison >développement back-end >Golang >Comment récupérer efficacement des documents MongoDB par ID à l'aide de la méthode FindId() de mgo ?
Dans la base de données Mongo, trouver un document spécifique par son identifiant unique, connu sous le nom de champ "_id", est une tâche courante. Voici un guide complet sur la façon d'y parvenir à l'aide de mgo, un pilote MongoDB populaire pour Go.
La méthode FindId() est spécifiquement conçue pour récupérer un document basé sur sur son champ "_id". Il prend un argument de type bson.ObjectId ou une chaîne représentant un ObjectId. Cependant, il est important de noter que lorsque vous utilisez la méthode FindId(), vous ne devez fournir que la valeur ObjectId, et non la carte bson.M{} entière comme argument.
Dans votre code, le problème réside dans l'utilisation incorrecte de la méthode FindId(). Voici le code corrigé qui devrait fonctionner :
err2 := c.FindId(bson.ObjectIdHex("58593d1d6aace357b32bb3a1")).One(&data)
Vous pouvez également utiliser la méthode Find() en spécifiant le champ et la valeur "_id" dans la carte bson.M{} :
err2 := c.Find(bson.M{"_id": bson.ObjectIdHex("58593d1d6aace357b32bb3a1")}). One(&data)
Si le document est trouvé, vous ne rencontrerez aucune erreur lors de l'exécution du code. Cependant, si le code renvoie toujours une valeur 0 pour data.IdCookie, cela suggère que le nom du champ pour l'identifiant dans la base de données est différent de celui que vous avez spécifié dans votre structure.
Pour garantir un mappage approprié entre votre structure Go et le document MongoDB, vous devez utiliser des balises struct. Par exemple, si le champ "_id" de la base de données est nommé "myid", vous pouvez le mapper à votre structure comme suit :
type id_cookie struct { IdCookie int `bson:"myid"` }
Pour améliorer les performances, vous devriez envisager d'éviter plusieurs connexions au serveur MongoDB pour chaque requête. L'établissement d'une seule session et sa réutilisation pour plusieurs requêtes peuvent accélérer considérablement les opérations. Pour plus d'informations sur l'optimisation de la gestion des connexions, reportez-vous à : [mgo - les performances des requêtes semblent constamment lentes (500-650 ms)](https://github.com/mongodb/mongo-go-driver/issues/1028)
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!