我在使用python连接sql修改表格的时间字段的时候,遇到这样一个问题:
ProgrammingError: (pymysql.err.ProgrammingError) (1064, “You have an
error in your SQL syntax; check the manual that corresponds to your
MariaDB server version for the right syntax to use near
‘14:41:32.713604 WHERE table_id =‘1’’ at line 1”)
[SQL: UPDATE jd_shop_comparison1_new SET create_time =2025-07-09 14:41:32.713604
WHERE table_id =‘1’ ] (Background on this error at:
https://sqlalche.me/e/14/f405)
原代码:
UPDATE_SQL = f"UPDATE table_name SET create_time ={create_time} WHERE table_id ='{table_id}' " #修改时间
engine.execute(UPDATE_SQL)
这个错误是由于 SQL 语句中的日期时间值没有正确使用引号引起的。
在我的 UPDATE 语句中,日期时间值 create_time 没有被引号包围,导致 MariaDB 无法正确解析这个值。
解决方法:
使用字符串引号
包围括号里的字符,包括日期、时间、文本等
例如:
UPDATE_SQL = f"UPDATE jd_shop_comparison1_new SET create_time = '{create_time}' WHERE table_id ='{table_id}' " #修改时间
engine.execute(UPDATE_SQL)
最终问题就解决了!
详细的错误图: