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 值,需要用单引号 '陈晓' 包裹,部分数据库也支持双引号,但单引号兼容性更好。
相关推荐
Solis程序员22 分钟前
MongoDB 超全入门到实战:从原理、CRUD到高可用架构
数据库·mongodb·架构
yurenpai(27届找实习中)26 分钟前
redis_点评(26.附近店铺——实现附近商家功能)
数据库·spring boot·redis
BullSmall28 分钟前
异构数据库(通俗 + 核心知识点)
数据库
Rick199331 分钟前
索引下推(ICP):在已经用到联合索引的前提下,减少回表次数,提升查询效率
数据库
金海境科技34 分钟前
实践分享!虚拟化数据恢复前三标准
数据库
不剪发的Tony老师42 分钟前
RedisME:一个现代化、轻量级Redis管理工具
数据库·redis
金海境科技1 小时前
实践分享!服务器数据恢复口碑榜
数据库
llilay1 小时前
企业级FastAPI后端模板搭建(三)整合日志Log
数据库·python·fastapi
treacle田1 小时前
使用达梦DTS迁移Oracle数据到达梦数据库过程步骤-记录总结
数据库·dts 迁移oracle到达梦
就叫飞六吧2 小时前
MySQL 驱动里那个 `cj` 到底是什么?
数据库·mysql