Maison >développement back-end >Golang >Comment puis-je obtenir une pagination MongoDB efficace avec mgo.v2 ?
Pagination MongoDB efficace à l'aide de mgo
MongoDB fournit une prise en charge intégrée de la pagination à l'aide de Query.Skip() et Query.Limit(). Cependant, cette méthode peut être lente pour les grands ensembles de résultats, car MongoDB doit parcourir tous les documents de résultats pour omettre ceux qui doivent être ignorés.
MongoDB propose une solution en fournissant une fonctionnalité curseur.min() qui vous permet de spécifier la première entrée d'index à partir de laquelle lister les résultats. Malheureusement, le pilote mgo.v2 n'a pas d'appels API pour spécifier curseur.min().
Pour obtenir une pagination efficace à l'aide de la fonctionnalité curseur.min() de MongoDB avec mgo.v2, vous pouvez utiliser Database.Run () pour exécuter directement les commandes MongoDB. La commande find prend en charge la spécification de l'argument min.
Après chaque lot de résultats, vous pouvez générer le document min à partir du dernier document du résultat de la requête et le définir avant d'exécuter la requête pour le lot suivant. Le document min doit contenir les valeurs de l'entrée d'index utilisée pour exécuter la requête.
Ce processus peut être effectué manuellement, comme décrit dans la réponse, ou vous pouvez utiliser une bibliothèque tierce comme github.com/ icza/minquery, qui fournit un wrapper pour configurer et exécuter les commandes de recherche MongoDB, y compris la spécification d'un curseur.
En utilisant minquery, vous pouvez spécifier le curseur min comme ceci :
q := minquery.New(session.DB(""), "users", bson.M{"country": "USA"}). Sort("name", "_id").Limit(10). Cursor(cursor)
où le curseur est le curseur obtenu à partir du lot précédent.
Notez que lorsque vous utilisez MinQuery.All(), vous devez fournir les noms des champs du curseur comme dernier argument. De plus, si vous récupérez des résultats partiels, vous devez inclure tous les champs qui font partie du curseur (l'entrée d'index) même si vous n'avez pas l'intention de les utiliser directement, car MinQuery.All() aura besoin de toutes les valeurs. des champs du curseur pour créer la valeur de curseur appropriée.
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!