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 值,需要用单引号 '陈晓' 包裹,部分数据库也支持双引号,但单引号兼容性更好。
相关推荐
百度安全2 小时前
HugeGraph 晋升 Apache 顶级项目 百度安全持续筑牢 AI 时代图数据基础设施
数据库·人工智能·安全·知识图谱
_376271532 小时前
JavaScript中闭包结合代理模式Proxy实现数据监听
jvm·数据库·python
ShiJiuD6668889992 小时前
综合练习(Javaweb)
数据库
User_芊芊君子2 小时前
从 0 到 1 学 MySQL:索引原理、事务特性、视图用法与 JDBC 实操全解析
大数据·数据库·mysql
八月瓜科技2 小时前
豆包启动付费会员测试,承诺基础服务永久免费,免费AI时代是否终结?
数据库·人工智能·科技·深度学习·机器人
人道领域2 小时前
【黑马点评日记】社交平台用户关注功能全解析Feed流相关操作
java·开发语言·数据库·redis·python
zhoutongsheng2 小时前
mysql如何处理表空间碎片问题_执行OPTIMIZE TABLE整理
jvm·数据库·python
lifewange2 小时前
如何查看本地的数据库里信息
数据库
PSLoverS3 小时前
Python如何实现测试场景编排_基于pytest的数据驱动组合策略
jvm·数据库·python