mysql·update语句报错:Data truncation: Truncated incorrect DOUBLE value: ‘系统开小差啦~请稍后再试‘

一. 背景

  • MySQL的update语句多次遇到这个问题,每次的原因都不同,但每个原因出现的频率都很高,在这里总结并记录一下目前为止出现过的原因。

二. 错误原因总结

1. 错误原因1. set后面用and连接
  1. 错误示例
update table set a = 'a' and b = 'b' where id = 1 (报错) 
  1. 解决方案:把update语句里set后面的”and”全部换成”,”
  2. 正确示例
update table set a = 'a', b = 'b' where id = 1 (正确) 
2. 错误原因2. 字符串字段连接用’+’号
  1. 错误示例
# 字段a是varchar类型 update table set a = a + '12' where id = 1 (报错) # 字段a是int类型 update table set a = a + 1 where id = 1 (正确) 
  1. 解决方案:用concat()连接多个字符串
  2. 正确示例
update table set a = concat(a,'12') where id = 1 (报错) 
  1. 不同数据库对多个字符串的支持
    • mysql数据库:CONCAT(),参数可以有多个;
    • Oracle数据库:CONCAT() 或 ||,参数只能有两个;
    • SQL Server:+

三. 参考资料

  1. 当使用update语句时出现Data truncation: Truncated incorrect DOUBLE value:??错误.
  2. sql 连接表的两个字段拼接成新字段 ,形成新字段插入
  3. SQL中字符串拼接

本文地址:https://blog.csdn.net/zijikanwa/article/details/107910186

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐