首页 >数据库 >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