Python スクリプトを使用して値 188 と 90 を MySQL データベースに挿入しようとすると、コードは正常に実行できません。次のコード スニペットは、失敗した試行を示しています。
import MySQLdb conn = MySQLdb.connect(host= "localhost", user="root", passwd="newpassword", db="engy1") x = conn.cursor() x.execute("SELECT * FROM anooog1") x.execute (" INSERT INTO anooog1 VALUES ('%s','%s') ", (188,90)) row = x.fetchall()
この問題は、挿入に使用された SQL クエリのエラーが原因で発生します。 MySQL テーブルにデータを挿入するための正しい構文は次のとおりです。
INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...)
提供されたコードでは、値を囲む一重引用符 ('') が正しくありません。これらを削除すると、クエリが正常に実行できるようになります。
さらに、データベースに加えられた変更をロールバックすることによる予期せぬエラーを防ぐために、例外処理メカニズムが追加されました。以下の変更されたコードは、正しい実装を示しています。
import MySQLdb conn = MySQLdb.connect(host= "localhost", user="root", passwd="newpassword", db="engy1") x = conn.cursor() try: x.execute("""INSERT INTO anooog1 VALUES (%s,%s)""",(188,90)) conn.commit() except: conn.rollback() conn.close()
この変更されたコードは、指定された MySQL テーブルに値 188 と 90 を正常に挿入します。
以上がPython MySQL INSERT ステートメントが失敗するのはなぜですか? どうすれば修正できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。