ホームページ > データベース > mysql チュートリアル > Python MySQL INSERT ステートメントが失敗するのはなぜですか? どうすれば修正できますか?

Python MySQL INSERT ステートメントが失敗するのはなぜですか? どうすれば修正できますか?

Mary-Kate Olsen
リリース: 2024-12-09 14:57:12
オリジナル
601 人が閲覧しました

Why Does My Python MySQL INSERT Statement Fail, and How Can I Fix It?

MySQL データベースへのデータの挿入

問題ステートメント

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 サイトの他の関連記事を参照してください。

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