Pymysql плохо форматирует параметрыPython

Программы на Python
Ответить
Anonymous
 Pymysql плохо форматирует параметры

Сообщение Anonymous »

Я только что перешел на новый venv с версией pymysql, обновленной с v1.1.0 до v1.1.1, и теперь у меня возникают ошибки SQL, когда параметры форматируются функцией Cursor.execute

Вот пример

Код: Выделить всё

client_id = float(2)
params = (client_id)
print(f"Parameters :\n\t{params}")
try:
cursor.execute("SELECT * FROM clients WHERE id = %s", params)
except:
print("EXCEPTION")
print(f"Query :\n\t{cursor._executed}")
А вот выполненный запрос

Код: Выделить всё

Parameters :
(2.0)
Query :
SELECT * FROM clients WHERE id = 2.0e0
Это не проблема, если я получаю данные, однако при вставке или обновлении данных происходит сбой

Код: Выделить всё

client_id = float(2)
balance = np.float64(1000)
params = (client_id, balance)
print(f"Parameters :\n\t{params}")
try:
cursor.execute("UPDATE client_balances SET balance = %s WHERE client_id = %s", params)
except:
print("EXCEPTION")
print(f"Query :\n\t{cursor._executed}")
Вывод:

Код: Выделить всё

Parameters :
(2.0, np.float64(1000.0))
EXCEPTION
Query :
UPDATE client_balances SET balance = np.float64(1000)e0 WHERE client_id = 2.0e0
Если я проверю исключение, я получу следующую ошибку

Код: Выделить всё

ProgrammingError - (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'e0, balance = np.float64(1000)e0, WHERE client_id = 2.0e0' at line 1")
Я понял, что если вручную принудительно форматировать параметры как строку, это работает.

Код: Выделить всё

client_id = float(2)
balance = np.float64(1000)
params = (client_id, balance)
print(f"Parameters :\n\t{params}")

refactored_params = []
for param in params:
refactored_params.append(str(param))

try:
cursor.execute("UPDATE client_balances SET balance = %s WHERE client_id = %s", refactored_params)
except:
print("EXCEPTION")
print(f"Query :\n\t{cursor._executed}")
Вывод:

Код: Выделить всё

Parameters :
(2.0, np.float64(1000.0))
Query :
UPDATE client_balances SET balance = '1000' WHERE client_id = '2.0'
Таким образом, я мог бы реализовать исправление, при котором я вручную конвертирую параметры перед вызовом выполнения, но поскольку у меня не было проблем до изменения моего venv, я хотелось бы понять, делаю ли я что-то не так, вместо того, чтобы найти неэффективный обходной путь.
Более того, я не могу поверить, что pymysql не может правильно преобразовать параметры в запрос, поэтому я думаю, что определенно делаю что-то не так.
Есть мысли по этому поводу? Должен ли я принудительно преобразовать строки вручную или изменить реализацию?

Подробнее здесь: https://stackoverflow.com/questions/791 ... parameters
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»