【SQL】使用UPDATE修改表字段的时候,遇到1054 或者1064的问题怎么办?

我在使用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)

原代码:

python 复制代码
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 无法正确解析这个值。

解决方法:

使用字符串引号包围括号里的字符,包括日期、时间、文本等

例如:

c 复制代码
UPDATE_SQL = f"UPDATE jd_shop_comparison1_new SET create_time = '{create_time}' WHERE table_id ='{table_id}' " #修改时间
engine.execute(UPDATE_SQL)

最终问题就解决了!

详细的错误图:

相关推荐
NaiLuo_4512 分钟前
MySQL基本查询
数据库·mysql
刺客xs12 分钟前
MYSQL数据库------多表查询
数据库·mysql
TimeFine16 分钟前
Android AI解放生产力(四)实战:解放绘制UI的繁琐工作
android
曹牧23 分钟前
Oracle:拼音码
数据库·oracle
BD_Marathon24 分钟前
【JavaWeb】日程管理03——准备数据库和实体类
数据库·oracle
大学生资源网26 分钟前
java毕业设计之面向校园的助力跑腿系统设计与实现源码(源码+文档+数据库)
java·数据库·mysql·毕业设计·源码·springboot
听到微笑28 分钟前
初探Nebula Graph核心架构设计
数据库·图数据库·nebula graph
sheji341633 分钟前
【开题答辩全过程】以 基于Android的社区车位共享管理系统的设计与实现为例,包含答辩的问题和答案
android
TimeFine1 小时前
Android AI解放生产力(三):认识custom_prompts和skills
android
summerkissyou19871 小时前
Android-Audio-为啥不移到packages/module
android·音视频