在我的项目中,我使用了txtAdvance的关键事件。
第1行的列'advance'被截断MySql数据
double gtotal = Double.parseDouble(txtGtotal.getText());
double ad = Double.parseDouble(txtAdvance.getText());
double due = gtotal - ad;
txtDue.setText(String.valueOf(due));
和第三行的运行后,我添加了一个Save按钮保存这些数据。下面给出的是该查询。
public void saveInvoice(JTextField txtgtotal, JTextField txtAdvance, JTextField txtDue, JTextField txtInID) {
try {
db.putData("INSERT INTO indetails(inid, gtotal, advance, due) VALUES('" + txtInID.getText() + "' ,'" + txtgtotal.getText() + "' , '" + txtAdvance.getText() + " ' " + " , '" + txtDue.getText() + "') ");
JOptionPane.showMessageDialog(null, txtAdvance.getText());
JOptionPane.showMessageDialog(null, "Invoice details saved");
}
catch (Exception e) {
JOptionPane.showMessageDialog(null, this.getClass().getName() + " first " + e);
}
}
我在第1行为'advance'列截断了MySql数据。 advance的数据类型是Double。但我找不到一种方法来放长度。
(作为一个例子
列名:独立同分布,数据类型:int(18){主键}
列名:INID,数据类型:int(18)
列名:gtotal ,数据类型:双
列名:预先,数据类型:双
列名:由于,数据类型:双
)
我正在使用MySQL查询浏览器。问题是当我向txtAdvance添加0值时出现此错误。
我正在使用JDBC连接。 – Dilini
'putData'方法是什么?你为什么不使用'PreparedStatement'? – agad
Your PreparedStatement应该看起来像这样:''INSERT INTO indetails(inid,gtotal,advance,due)VALUES(?,?,?,?)',你应该使用'setDouble(2,ad)'设置'advance'列。 – agad