首頁 >資料庫 >mysql教程 >為什麼我的 Python MySQL INSERT 語句會失敗,要如何修復?

為什麼我的 Python MySQL INSERT 語句會失敗,要如何修復?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-12-09 14:57:12601瀏覽

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()

此修改後的程式碼應該會成功將值 188 和 90 插入指定的 MySQL 表中。

以上是為什麼我的 Python MySQL INSERT 語句會失敗,要如何修復?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn