无法在Java中的preparedStatement中设置Date

时间:2013-09-15 07:26:33

标签: java mysql

如果我改变

ps.setString(3, ((JTextField)txtDateRecv.getDateEditor().getUiComponent()).getText());

ps.setDate(3, ((JTextField)txtDateRecv.getDateEditor().getUiComponent()).getText());然后我收到Netbeans IDE 7.2.1中显示的错误消息

mySQL数据库字段的列设置为“DATE”。

有人可以帮我理解问题所在吗?

感谢您的帮助。部分代码如下;

private void btnSaveActionPerformed(java.awt.event.ActionEvent evt) {                                        
        // TODO add your handling code here:
        try{
            String sql="insert into inventory(DNO,TITLE,RDATE,COPIES) values(?,?,?,?)";
            ps=con.prepareStatement(sql);
            ps.setString(1, txtDvdNo.getText());
            ps.setString(2, txtMovTitle.getText());
            ps.setString(3, ((JTextField)txtDateRecv.getDateEditor().getUiComponent()).getText());
            ps.setString(4, txtCopies.getText());
            ps.execute();
            JOptionPane.showMessageDialog(txtCopies, "New Record added");
        }
        catch(SQLException e){
            JOptionPane.showMessageDialog(Inventory.this, e.getMessage());
        }
        showInventoryTable();
    }        

1 个答案:

答案 0 :(得分:0)

在JTextField中解析日期的文本表示

   java.util.Date date = new SimpleDateFormat(your_date_format).parse(((JTextField)txtDateRecv.getDateEditor().getUiComponent()).getText());

然后创建它的java.sql.Date并将其设置为PreparedStatement

   ps.setDate(3, new java.sql.Date(date.getTime()));