zoukankan      html  css  js  c++  java
  • 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


  • 相关阅读:
    Git 使用juju
    svn Q&A
    ubuntu 常用命令
    java中set的交集、差集、并集的简单实现
    java 读写JSON(一)
    java类型转化之SimpleDateFormat-时间转化
    maven 基本常识以及命令
    maven遇到的问题
    java编程思想,对象导论
    条目5:避免创建不必要的对象
  • 原文地址:https://www.cnblogs.com/softidea/p/9835748.html
Copyright © 2011-2022 走看看