【问题标题】:Double value stored as zero in the database双值在数据库中存储为零
【发布时间】:2014-02-18 13:39:47
【问题描述】:

我的 postgres 数据库中有一个表,即。具有列的学生,即名称标记1标记2,其中名称是varchar(20),标记1和标记2是双精度数据类型。

我在 java 类中使用准备好的语句

PreparedStatement ps=con.preparestatement("insert into student values(?,?,?);
ps.setString(1,t.getUname());
ps.setDouble(2,t.getUmarks1());
ps.setDouble(3,t.getUmarks2());
status=ps.executeUpdate();

但是当发送一个双精度值时,它会显示我的问题中提到的上述错误。

我有另一个定义了 getter 和 setter 的类。如下。

public class User {  
private String uname;
       private double umarks1,umarks2;  

public String getUname() {  
 return uname;  
}  

public void setUname(String uname) {  
 this.uname = uname;  
}  

public double getUmarks1() {  
 return umarks1;  
}  

public void setUmarks1(double umarks1) {  
 this.umarks1 = umarks1;  
}  

public double getUmarks2() {  
 return umarks2;  
}  

public void setUmarks2(double umarks2) {  
  this.umarks2 = umarks2;  
 }  

}  

如果我将数据类型更改为双倍,它会在数据库中保存一个 0。我想保存一个双精度值。我该如何解决这个问题?

【问题讨论】:

    标签: java postgresql


    【解决方案1】:

    我认为最好的方法是更改​​您的 Java 类以反映您的数据模型

    1) 将 marks 字段和 getter/setter 更改为 double

    2) 将PreparedStatement 更改为setDouble

    setDouble

    【讨论】:

    • 我做了同样的事情,我将标记字段更改为 double,将 PreparedStatement 更改为 setDouble,但如果我对数据库执行此操作,则会返回 0
    • 显示你尝试过的代码,而不是明显错误的代码
    • 那么现在没有错误了吗?您是否在调试器中确认了这些值?
    • 是的,没有错误。该值存储在数据库中,但为零。
    • 插入前检查值。此外,我发现按名称指定列更安全,例如String insertTableSQL = "INSERT INTO DBUSER" + "(USER_ID, USERNAME, CREATED_BY, CREATED_DATE) VALUES" + "(?,?,?,?)";
    猜你喜欢
    • 2021-11-01
    • 2023-02-01
    • 1970-01-01
    • 1970-01-01
    • 2012-12-27
    • 2011-10-15
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多