Truncated incorrect DOUBLE value: 'NO_REFUND'
Posted softidea
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Truncated incorrect DOUBLE value: 'NO_REFUND'相关的知识,希望对你有一定的参考价值。
解决办法:
mysql中,如果一个字段是字符串,则一定要加单引号
问题原因:
`item_refund_state` varchar(255) NOT NULL
item_refund_state字段的类型是varchar但where条件中使用了item_refund_state=0
如果where条件中tid对应item_refund_state字段值不是字符串0,而是‘NO_REFUND‘之类的字符串时,就会报下面的错
Truncated incorrect DOUBLE value: ‘NO_REFUND‘
类似的案例:
报错信息:
[SQL]
UPDATE 表 set times = 1 where type = 1 and times = 0
[Err] 1292 - Truncated incorrect DOUBLE value: ‘a‘
解决方案:
属于类型错误,type为vachar类型,具体是什么样的查询顺序我也不太清楚。经过测试,
我觉得是 times = 0 的条件中,含有 type = a 的结果,所以 user_type=1,需要添加单引号。
结果:
UPDATE 表 set times = 1 where type = ‘1‘ and times = 0
最后:
一定要严格写sql,vachar类型的一定用单引号,否则索引都使用不上。
https://www.cnblogs.com/cang12138/p/7268914.html
引发此类报错的另一种可能性:update语句中进行set多个字段时,使用and进行连接。解决办法:使用 英文逗号 即可
https://stackoverflow.com/questions/3456258/mysql-truncated-incorrect-double-value
以上是关于Truncated incorrect DOUBLE value: 'NO_REFUND'的主要内容,如果未能解决你的问题,请参考以下文章
Truncated incorrect DOUBLE value:
Truncated incorrect DOUBLE value: 'deleted'
mysql - Truncated incorrect DOUBLE value: 'undefined'
ERROR 1292 (22007): Truncated incorrect DOUBLE value: 'asfsda1'
com.mysql.jdbc.MysqlDataTruncation: Data truncation: Truncated incorrect DOUBLE value:...