Java 在数据库中存储为零的双精度值

Java 在数据库中存储为零的双精度值,java,postgresql,Java,Postgresql,我在我的postgres数据库中有一个表,即student,它有两列,即名称marks1 marks2,其中名称是varchar(20),marks1和marks2是双精度数据类型 我正在java类中使用一个准备好的语句 PreparedStatement ps=con.preparestatement("insert into student values(?,?,?); ps.setString(1,t.getUname()); ps.setDouble(2,t.getUmarks1());

我在我的postgres数据库中有一个表,即student,它有两列,即名称marks1 marks2,其中名称是varchar(20),marks1和marks2是双精度数据类型

我正在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类以反映数据模型

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

2) 将
PreparedStatement
更改为
setDouble


请参见

我也这样做了,我将marks字段更改为double,将PreparedStatement更改为setDouble,但如果我这样做,则会返回一个0。请显示您尝试的代码,而不是明显错误的代码。因此,现在没有错误了?您确认了调试器中的值了吗?是的,没有错误。该值存储在数据库中,但为零。请在插入之前检查这些值。此外,我发现按名称指定列更安全,例如字符串insertTableSQL=“INSERT INTO DBUSER”+(用户ID、用户名、创建人、创建日期)值“+”(?,?,?);