Utilisation efficace de MySQLDB SSCursor pour de grands ensembles de résultats
Lors de la gestion de vastes ensembles de résultats impliquant des centaines de milliers de lignes ou plus, une gestion efficace de la mémoire devient crucial. En tant que tel, le SScursor MySQLDB (Streaming Select Cursor) apparaît comme un outil approprié pour minimiser la consommation de mémoire.
Distinction entre Fetchall() avec le curseur de base et SSCursor
Contrairement à la croyance populaire, exécuter fetchall() à partir d'un SScursor consomme plus de mémoire qu'à partir d'un curseur de base. En effet, un SScursor récupère les résultats progressivement du serveur par morceaux, tandis que fetchall() télécharge l'intégralité du jeu de résultats en mémoire. Par conséquent, utiliser fetchall() devient contre-intuitif pour les scénarios de mémoire limitée.
Itérer les résultats avec SSCursor
Pour diffuser efficacement les résultats d'un SScursor ligne par ligne. par ligne, utilisez la méthode suivante :
import MySQLdb.cursors
connection=MySQLdb.connect(
host="thehost",user="theuser",
passwd="thepassword",db="thedb",
cursorclass = MySQLdb.cursors.SSCursor)
cursor=connection.cursor()
cursor.execute(query)
for row in cursor:
print(row)
Cette méthode parcourt l'ensemble de résultats sans stocker l'intégralité du contenu en mémoire, consommant un minimum de ressources.
Optimisations supplémentaires
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3