Truncated incorrect DOUBLE value: 'NO_REFUND'

本文解析了在Mysql中使用VARCHAR类型字段时常见的错误,即未正确使用单引号导致的数据类型不匹配问题。通过实例展示了错误的SQL语句如何引发数据截断警告,并提供了正确的SQL语法修正方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决办法:
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


 

转载于:https://www.cnblogs.com/softidea/p/9835748.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值