【发布时间】: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