1

我正在做一个个人项目。我正在创建一个打卡时钟程序,所以我需要帮助的部分是用户在 jTextField 中输入 uid 的地方。因此,我需要检索 uid(#######),然后使用 sql 语句在数据库中搜索该 uid。这就是我到目前为止所拥有的。问题是 jTextField1.getText 下有一条红线,当我运行它时,说 =

"setInt(int,int) in java.sql.PreparedStatement cannot be applied to (int,java.lang.String) pstmt.setInt(1, jTextField1.getText());"

任何帮助表示赞赏。谢谢你。

private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
    // TODO add your handling code here:
    try{
        stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
        String sql = "SELECT * FROM Students WHERE STUDENTID = ?";
        PreparedStatement pstmt = con.prepareStatement(sql);
        pstmt.setInt(1, jTextField1.getText()); // Retrieve uid from jTextField
        ResultSet rs = pstmt.executeQuery();
        while(rs.next()){
            String first = rs.getString(2);
            String last = rs.getString(3);
            String hours = rs.getString(6);

            fName.setText(first);
            lName.setText(last);
            tHours.setText(hours);
        }
    }
    catch(SQLException err){
        JOptionPane.showMessageDialog(Student.this, err.getMessage());
    }

}
4

2 回答 2

6

jTextField1.getText()将返回 String 用于parseInt转换为 int

pstmt.setInt(1, Integer.parseInt(jTextField1.getText()));
于 2012-06-13T06:17:07.323 回答
5

正如您从文档中看到的那样,该setInt()方法将两个参数都作为int.

public void setInt(int parameterIndex,
                   int x)

所以,你需要改变这个:

 pstmt.setInt(1, jTextField1.getText()); 

到:

 pstmt.setInt(1, Integer.parseInt(jTextField1.getText())); 

因为该getText()方法返回一个 String

于 2012-06-13T06:18:56.850 回答