以下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
。请注意,
mysql.connector
使用的parameter markers可能看起来与Python字符串格式中使用的%s
相同,但关系只是巧合。一些数据库适配器(如oursql
和sqlite3
)使用?
作为参数标记,而不是%s
。使用单一报价
sql='插入学生(id、fname、lname、school)值%s、%s、%s、%s)' 值=(4,“卡扎菲”,“阿达穆”,“非正式的”)
a.execute(sql,values)
mydb.commit() 打印(a.rowcount,“已插入记录”。)
相关问题 更多 >
编程相关推荐