一. 背景 MySQL的update语句多次遇到这个问题,每次的原因都不同,但每个原因出现的频率都很高,在这里总结并记录一下目前为止出现过的原因。 二. 错误原因总结 1. 错误原因1. set后面用and连接 错误示例 update table set a = 'a' and b = 'b' where id = 1 (报错) 解决方案:把update语句里set后面的"and"全部换成","正确示例 update table set a = 'a', b = 'b' where id = 1 (正确) 2. 错误原因2. 字符串字段连接用’+'号 错误示例 # 字段a是varchar类型 update table set a = a + '12' where id = 1 (报错) # 字段a是int类型 update table set a = a + 1 where id = 1 (正确) 解决方案:用concat()连接多个字符串正确示例 update table set a = concat(a,'12') where id = 1 (报错) 不同数据库对多个字符串的支持 mysql数据库:CONCAT(),参数可以有多个;Oracle数据库:CONCAT() 或 ||,参数只能有两个;SQL Server:+ 三. 参考资料 当使用update语句时出现Data truncation: Truncated incorrect DOUBLE value:??错误.sql 连接表的两个字段拼接成新字段 ,形成新字段插入SQL中字符串拼接