Подтвердить что ты не робот

Не все параметры были использованы в инструкции SQL (Python, MySQL)

Я получаю сообщение об ошибке на следующем 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

Вы понимаете, почему?

4b9b3361

Ответ 1

Маркер параметра %s не %d.

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

Обратите внимание, что маркеры параметров, используемые mysql.connector, могут выглядеть так же, как %s, используемые в форматировании строки Python, но отношения являются только случайными. Некоторые адаптеры баз данных, такие как oursql и sqlite3, используют ? как маркер параметра вместо %s.

Ответ 2

используйте одинарные кавычки

sql = 'вставить в значения Student (id, fname, lname, school) (% s,% s,% s,% s)' значения = (4, "Каддафи", "Адаму", "Информатик")

a.execute(sql, values)

mydb.commit() print (a.rowcount, "запись вставлена")