Maison >base de données >tutoriel mysql >Pourquoi mon script Python ne parvient-il pas à mettre à jour une base de données MySQL même s'il affiche des lignes mises à jour ?

Pourquoi mon script Python ne parvient-il pas à mettre à jour une base de données MySQL même s'il affiche des lignes mises à jour ?

DDD
DDDoriginal
2024-11-03 08:07:30745parcourir

Why Does My Python Script Fail to Update a MySQL Database Even Though It Shows Rows Updated?

Problème de mise à jour de la base de données dans le script Python résolu

Dans une requête récente, il a été découvert qu'un script Python conçu pour mettre à jour une base de données MySQL était par erreur, ne pas mettre à jour la table. Après une enquête plus approfondie, le script s'est avéré contenir le code suivant :

<code class="python">dbb = MySQLdb.connect(host="localhost", 
       user="user", 
       passwd="pass", 
       db="database") 
try:
   curb = dbb.cursor()
   curb.execute ("UPDATE RadioGroups SET CurrentState=1 WHERE RadioID=11")
   print "Row(s) were updated :" +  str(curb.rowcount)
   curb.close()
except MySQLdb.Error, e:
   print "query failed<br/>"
   print e  </code>

Le script a rencontré des problèmes malgré la déclaration que les lignes avaient été mises à jour. La cause de cette divergence s’est avérée être l’absence de dbb.commit(). Pour garantir que les mises à jour effectuées à l'aide d'un script Python sont correctement appliquées à la base de données MySQL, il est crucial d'incorporer dbb.commit() après avoir utilisé curb.execute. Cette fonction valide toutes les modifications que vous avez « chargées » sur le serveur MySQL, les rendant permanentes dans la base de données.

En implémentant cette modification, le script Python mettra à jour avec succès la table MySQL comme prévu.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn