zoukankan      html  css  js  c++  java
  • Truncated incorrect DOUBLE value: 'd'的解决方法(jdbc)

    今天写jdbc中dao的增删改查时遇到了一个问题,花费了好长时间,不过还好,有我峰哥出头,问题解决了,在这做个分享,对峰哥表达一下感激之情

    网上搜索到的对“Truncated incorrect DOUBLE value”的解决方法主要是这两种:
          ①修改了多个列的值而各列之间用逗号连接而不要用and
                 错误写法示例:

    String sql = "update user set username=? and password=? where id=?";


                 正确写法示例:

    String sql = "update user set username=? , password=? where id=?";


    ②SQL语句在拼接字符串时使用函数CONCAT()而不要用“+”
    但我只修改一列而且是直接传参的啊= =。一开始我尝试通过preparedstatement设置动态参数,即
    String sql="UPDATE arrange SET askForLeave='是' WHERE employeeNum=? and arrangeDate=?";
    这次不报Truncated incorrect DOUBLE value了,改报语法错误了= =
    于是把and替换成or,结果正确;把参数改成同格式的常量,结果也正确;去掉一个条件,结果还是正确;说明错误出在两个参数上

    最后我的解决方法是把
    String sql="UPDATE arrange SET askForLeave='是' WHERE employeeNum=“+employeeNum+” and arrangeDate="+leaveDate;
    改成了
    String sql="UPDATE arrange SET askForLeave='是' WHERE employeeNum='"+employeeNum+"' and arrangeDate='"+leaveDate+"'"
    在字符串变量前后又加了单引号

    希望以后别再被掉这坑了。。。。。。很难受

  • 相关阅读:
    接口的上溯造型——《Thinking in Java》随笔015
    数据库
    小结
    异常及String
    多态&接口
    继承&封装
    Java 类 对象 包
    Java 方法的应用
    Java数组的运用
    Java代码运用及算法思路养成——用*号输出形状
  • 原文地址:https://www.cnblogs.com/zyx110/p/10753049.html
Copyright © 2011-2022 走看看