UPDATE ... SET 多字段赋值

update afinfo set age=45 and birth=birth-YEAR(45) where name="陈晓";

------SQL 错误 1292 22001: Data truncation: Incorrect datetime value: '45'

SQL 语句存在多个语法和逻辑错误,导致了 Data truncation: Incorrect datetime value: '45' 错误。

错误原因拆解:
  1. SET 子句使用了错误的 AND UPDATE 语句中,多个字段赋值应该用 ** 逗号 ,** 分隔,而不是 ANDANDWHERE 子句的逻辑运算符,写在 SET 里会被解析为逻辑判断,导致语法异常。

  2. birth=birth-YEAR(45) 是无效语法 YEAR() 函数需要传入一个日期 / 时间字段,而不是数字 45birth-YEAR(...) 这种运算方式也完全错误,无法实现日期的加减。

  3. 数据类型错误 由于上述语法错误,MySQL 会错误地尝试将 45 作为日期时间值解析,因此报出了 Incorrect datetime value: '45' 错误。


✅ 正确的 SQL 语句

如果你的需求只是修改陈晓的年龄为 45,正确写法如下:

sql

复制代码
UPDATE ainfo 
SET age = 45 
WHERE name = '陈晓';

📌 进阶场景:同时更新年龄和出生日期

如果你的表中同时有 agebirth 字段,且需要让两者保持一致(比如设置年龄为 45 岁,自动更新出生日期),可以用以下两种方式实现:

方式 1:直接指定年龄,不更新出生日期

(推荐,除非业务强制要求维护两个冗余字段)

sql

复制代码
UPDATE ainfo 
SET age = 45 
WHERE name = '陈晓';
方式 2:设置年龄为 45 岁,自动推算出生日期

(假设当前年份为 2026 年,MySQL 环境)

sql

复制代码
UPDATE ainfo 
SET age = 45,
    birth = DATE_SUB(CURDATE(), INTERVAL 45 YEAR)
WHERE name = '陈晓';

💡 关键语法说明

  1. UPDATE ... SET 多字段赋值 多个字段之间必须用 ** 逗号 ,** 分隔,不能用 AND

    sql

    复制代码
    -- 正确
    UPDATE table SET col1 = val1, col2 = val2 WHERE ...;
    -- 错误
    UPDATE table SET col1 = val1 AND col2 = val2 WHERE ...;
  2. 日期运算函数

    • CURDATE():获取当前日期(如 2026-05-06
    • DATE_SUB(date, INTERVAL N YEAR):从指定日期减去 N 年
    • YEAR(date):获取日期的年份(如 YEAR('2026-05-06') 返回 2026

🛠️ 常见避坑指南

  • 不要在 UPDATESET 子句中使用 AND 连接多个字段赋值。
  • agebirth 属于冗余字段,业务中建议只维护 birth,通过 TIMESTAMPDIFF(YEAR, birth, CURDATE()) 动态计算年龄,避免数据不一致。
  • 字符串类型的 name 值,需要用单引号 '陈晓' 包裹,部分数据库也支持双引号,但单引号兼容性更好。
相关推荐
ClouGence17 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将19 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils2 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波2 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_3 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_6 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence7 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神7 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据8 天前
数据服务化时代:企业数据能力输出的核心路径
数据库