Python - MySQLdb параметризованный запрос

Я пытаюсь создать простой скрипт для изменения некоторых данных MySQL, но я немного запутался в параметризованных запросах. Код выглядит так:

reader_id = sys.argv[1]
cmd_id = sys.argv[2]

conn = mysql.connect(user='...', passwd='...', host='...', db='...')
curs = conn.cursor()

mysql_data = {
    "reader_id": int(reader_id),
    "cmd_id": int(cmd_id)
}

curs.execute("UPDATE `reader_config_hw` SET `changed_` = '1' "
             "WHERE `object_id` = %(reader_id)d AND `id` = %(cmd_id)d;", mysql_data)

curs.execute("UPDATE `reader` SET `check_for_command` = '1' WHERE `id` = %(reader_id)d", mysql_data)

и результат ошибки

Traceback (most recent call last):
  File "./main.py", line 25, in <module>
    "WHERE `object_id` = %(reader_id)d AND `id` = %(cmd_id)d;", mysql_data)
  File "/usr/lib64/python3.6/site-packages/MySQLdb/cursors.py", line 210, in execute
    query = query % args
TypeError: %d format: a number is required, not str

Это говорит о том, что число требуется, но я уже изменил тип переменной int(reader_id), это правильно?

1 ответ

Решение

Попробуйте изменить "WHERE 'object_id' = %(reader_id)d AND 'id' = %(cmd_id)d;"

в

"WHERE 'object_id' = %(reader_id)s AND 'id' = %(cmd_id)s;"

Я думаю, что 'd' после вашей переменной вызывает "цифру", тогда как вам нужно использовать строку.

РЕДАКТИРОВАТЬ: чтобы уточнить, строки могут быть использованы вместо целых чисел в запросах MySQL

Другие вопросы по тегам