在java中调用Method时出现NullPointerException

时间:2014-03-11 18:24:51

标签: java nullpointerexception

我的项目中有一个方法如下:

public String fillsubject(String id,int type){
    if(id.isEmpty())
        return "";
    String result="";
    String query="select sub_name from subject where sub_id='"+id+"'";
    if(type==1)
        query="select lab_name from lab where lab_id='"+id+"'";
    try {
        ResultSet rs2=st2.executeQuery(query);
        rs2.first();
        result=rs2.getString(1);
        rs2.close();
    } catch (Exception ex) {
        JOptionPane.showMessageDialog(this, ex);
    }
    return result;
}

我在下面写这个名字。

    try {
        rs = st.executeQuery("Select sub1,sub2,sub3,sub4,sub5,sub6,sub7,lab1,lab2,lab3,class_id from class where standard='" + jComboBox32.getSelectedItem().toString() + "' and section='" + jComboBox26.getSelectedItem().toString() + "';");
        rs.first();
        jTextField39.setText(fillsubject(rs.getString(1),0));
        jTextField32.setText(fillsubject(rs.getString(2),0));
        jTextField33.setText(fillsubject(rs.getString(3),0));
        jTextField40.setText(fillsubject(rs.getString(4),0));
        jTextField35.setText(fillsubject(rs.getString(5),0));
        jTextField41.setText(fillsubject(rs.getString(6),0));
        jTextField38.setText(fillsubject(rs.getString(7),0));
        jTextField37.setText(fillsubject(rs.getString(8),1));
        jTextField34.setText(fillsubject(rs.getString(9),1));
        jTextField36.setText(fillsubject(rs.getString(10),1));
        jLabel198.setText(rs.getString(11));
    } catch (SQLException e) {
        JOptionPane.showMessageDialog(DeleteStudent, e);
    } 

问题是在调用rs.getString()时,它有时在数据库中具有null值。在这种情况下,我在fillsubject()方法中得到一个nullpointer异常。现在我的问题是如何解决这个问题。 提前致谢。

4 个答案:

答案 0 :(得分:2)

在方法fillsubject()中,而不是使用:

if (id.isEmpty())

使用:

if (id == null || id.isEmpty())

,在尝试访问之前,您将检查id String对象是否为null

另外,只是为了添加信息,在建议的if子句中,id.isEmpty()仅在第一次比较结果为假时才会执行(仅当id不为null时)。当id为null时,永远不会执行id.isEmpty()

答案 1 :(得分:1)

在方法的开头,添加:

if (id == null)
    return ""; // or whatever you want to represent no value

答案 2 :(得分:0)

您始终可以自行检查String返回的getString是否为null

if (result == null) { // handle it! }

一般情况下,您可以使用the wasNull() method检查最后一次" get"方法代表null。当获取int之外没有null的代表的其他数据类型时,这就变得很有必要。

  

报告最后一列读取的值是否为SQL NULL。请注意,您必须首先调用列上的其中一个getter方法以尝试读取其值,然后调用方法wasNull以查看读取的值是否为SQL NULL。

if (rs.wasNull()) {
    // previous "get" method represents a DB null.
}

答案 3 :(得分:0)

我认为处理此问题的最佳方法是在结果集上运行if语句,然后根据您的应用程序处理结果。 EX:

if(rs.wasNull()){
// Handle the result } 
else { 
//handle the rest of your code
}

我希望这是有道理的。