ホームページ > データベース > mysql チュートリアル > Python を使用した MySQL データベースの更新がデータベースに反映されないのはなぜですか?

Python を使用した MySQL データベースの更新がデータベースに反映されないのはなぜですか?

Susan Sarandon
リリース: 2024-12-06 19:38:14
オリジナル
570 人が閲覧しました

Why Aren't My MySQL Database Updates with Python Reflecting in the Database?

MySQL と Python によるデータベース更新のトラブルシューティング

この問題は、Python の MySQLdb ライブラリを使用して MySQL データベースを更新するときに発生します。次のコードが実行されています:

import MySQLdb

conn=MySQLdb.connect(host="localhost", user="root", passwd="pass", db="dbname")
cursor=conn.cursor()

cursor.execute("UPDATE compinfo SET Co_num=4 WHERE ID=100")
cursor.execute("SELECT Co_num FROM compinfo WHERE ID=100")
results = cursor.fetchall()

for row in results:
    print row[0]

print "Number of rows updated: %d" % cursor.rowcount

cursor.close()
conn.close()
ログイン後にコピー

このコードを実行すると、成功したように見え、データベースが更新されたことが示されます。ただし、その後、MySQL コマンド ライン インターフェイスからクエリを実行すると、更新が適用されていないことがわかります。

原因

問題は、コミット操作がないことにあります。 MySQLdb はデフォルトでトランザクションを有効にし、更新を永続化するには明示的なコミットを必要とします。コミットしないと、変更はデータベースに保存されません。

解決策

これを解決するには、以下に示すように、接続を閉じる前に conn.commit() をインクルードします。

import MySQLdb

conn=MySQLdb.connect(host="localhost", user="root", passwd="pass", db="dbname")
cursor=conn.cursor()

cursor.execute("UPDATE compinfo SET Co_num=4 WHERE ID=100")
cursor.execute("SELECT Co_num FROM compinfo WHERE ID=100")
results = cursor.fetchall()

for row in results:
    print row[0]

print "Number of rows updated: %d" % cursor.rowcount

**conn.commit()**  # Commit changes to database

cursor.close()
conn.close()
ログイン後にコピー

conn.commit() を組み込むことにより、データベースに加えられた変更は正常に永続化されます。

以上がPython を使用した MySQL データベースの更新がデータベースに反映されないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート