python - 并非所有参数都在 SQL 语句中使用(Python、MySQL)

标签 python mysql sql

以下 Python 代码出现错误:

import mysql.connector
cnx = mysql.connector.connect(user='root', password='',
                          host='127.0.0.1',
                          database='DB')
cursor = cnx.cursor()

Name = "James"
Department = "Finance"
StartYear = 2001
CurrentPos = 2001
Link = ""

add_user = ("INSERT INTO DB.tbluser "
       "(username, department, startyear, currentpos, link) "
       "VALUES (%s, %s, %d, %d, %s)")
data_user = (Name, Department, StartYear, CurrentPos, Link)
cursor.execute(add_user, data_user)
cnx.commit()
cursor.close()
cnx.close()

错误信息是

mysql.connector.errors.ProgrammingError: Not all parameters were used in the SQL statement

你明白为什么吗?

最佳答案

参数标记是 %s 而不是 %d

add_user = """INSERT INTO DB.tbluser 
              (username, department, startyear, currentpos, link) 
              VALUES (%s, %s, %s, %s, %s)"""

请注意 parameter markers mysql.connector 使用的可能看起来与 Python 字符串格式化中使用的 %s 相同,但这种关系只是巧合。一些数据库适配器,如 oursqlsqlite3 使用 ? 作为参数标记而不是 %s

关于python - 并非所有参数都在 SQL 语句中使用(Python、MySQL),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20818155/

相关文章:

php - 使用 PHP 显示从 MySQL 数据库检索的数据时出现问题

python - 如何在 Windows 上使用 pip 和 python 3.4?

php - mysqli_stmt::bind_param() 错误:使用连接进行查询

mysql - 如何使用 MySQL Group_concat

sql - 在 SQL Server 存储过程中显示父行下的子行

python - Django,ManyToManyField - ProgrammingError : relation foo_bar does not exist. 在迁移中被识别,但从未创建关系

c# - 插入多对多数据库?

python - numpy.fft.fft 和 numpy.fft.fftfreq 有什么区别

python - 如何比较 pandas 数据框中第二列的值与第一列的相同值?

python - 在 BeautifulSoup 中获取 HTML <a> 标签的文本