1

私は、ユーザーがフォームに必要な基準を入力することになっているプロジェクトに取り組んでおり、これらの基準に応じて、サーブレットがデータベースから適切な結果を返します。私はmysqlサーバーを使用しています。私の問題は、そのために使用した準備済みステートメントが (ユーザーが可変数の基準で検索できるため) 常に null を返すことです。

Exception: null java.lang.NullPointerException at    
Servlet_GrowerResults.doGet(Servlet_GrowerResults.java:102)

ResultSet を Servlet_GrowerResults に返すクラス GetData のメソッド fetchGrowers を次に示します。

private PreparedStatement stmt_growers=null;
private ResultSet rs_growers;
private final String getGrowersQuery="select * from grower where name like ? and surname like ? and area like ? and partnership like ?;";

public ResultSet fetchGrowers(String criteria_name,String criteria_surname,String criteria_area, String criteria_partnership){
    try{
        stmt_growers=dbcon.getConnection().prepareStatement(getGrowersQuery);
        stmt_growers.setString(1, criteria_name);
        stmt_growers.setString(3, criteria_surname);
        stmt_growers.setString(5, criteria_area);
        stmt_growers.setString(7, criteria_partnership);

        rs_growers=stmt_growers.executeQuery();
        return rs_growers;
    }
    catch(Exception e9){
        errorMessage = "Error while getting all growers from database!<br>" + e9.getMessage();
        return null;
    }

ResultSet が初期化される行は次のとおりです。提出された基準のすべてのケースをカバーする場合は、他にもあります

   try{
        getData.getDBcon().open();
        ResultSet rsAreas=getData.fetchGrowerAreas();
        ResultSet rsPartnership=getData.fetchGrowerPartnership();
        ResultSet rsGrowersReturned;

        String sqlWildcard="%";

        //Cases of criteria submited by the user,
        //in order to send the apropriate parameters
        //to the PreparedStatement

        //1st case: searching without names criteria
        if( (criteriaNames.length()>0) && (!(criteriaAreas.length()>0)) && (!(criteriaPartnerships.length()>0)) ){
            rsGrowersReturned=getData.fetchGrowers(sqlWildcard,sqlWildcard,criteriaAreas,criteriaPartnerships);
        }

そして、これが例外が指す行です。具体的には、102 行目は while(rsGrowersReturned.next()) です。

 if((sorting.equals("περιοχή"))){
        while(rsAreas.next()){
                out.println("<table>");
                String area=rsAreas.getString("area");
                area = new String(area.getBytes("ISO-8859-1"), "ISO-8859-7");
                out.println("<tr><th>"+rsAreas.getString("area")+"</th></tr>");

    /*line 102*/ while(rsGrowersReturned.next()){
                    if(rsGrowersReturned.getString("area").equals(rsAreas.getString("area"))){
                        String name=rsGrowersReturned.getString("name");
                        name = new String(name.getBytes("ISO-8859-1"), "ISO-8859-7");
                        String surname=rsGrowersReturned.getString("surname");
                        surname = new String(surname.getBytes("ISO-8859-1"), "ISO-8859-7");
                        String partnership=rsGrowersReturned.getString("partnership");
                        partnership = new String(partnership.getBytes("ISO-8859-1"), "ISO-8859-7");

                        out.println("<tr><td>"+name+" "+surname+"</td>");
                        out.println("<td>"+partnership+"</td></tr>");
                    }//end of neaced if
                }//end of second while
            }//end of first while
            out.println("</table>");
        }//end of if

実際に問題が発生していることがわかります.2番目に到達する前に、最初の領域を本来のように印刷し、次に例外!!!

私はmysqlサーバーにSQLクエリを直接試してみましたが、うまくいきましたが、問題が見つかりません! すべての回答をいただければ幸いです。

4

3 に答える 3

3

PrepareStatement入力パラメータを順番に設定する必要があります。

stmt_growers.setString(1, criteria_name);
stmt_growers.setString(2, criteria_surname);
stmt_growers.setString(3, criteria_area);
stmt_growers.setString(4, criteria_partnership);
于 2012-12-09T15:47:22.777 に答える
1

ここで SQLException が飲み込まれているに違いありません。

catch(Exception e9){
    errorMessage = "Error while getting all growers from database!<br>" + e9.getMessage();
    return null;
}

発生した例外をログに記録するか、適切な上位レベルの例外を再スローするように修正してください。エラー時に null を黙って返すことは、常に悪い考えです。

発生した例外を投稿に追加すると、原因を追跡するのに役立ちます。

于 2012-12-09T15:46:44.753 に答える
0

fetchGrowersのエラー処理は最適ではありません。単に例外をキャッチし、未使用のメッセージを作成してnullを返すだけです。これにより、後でnullpointerが発生しますが、その理由はわかりません。少なくとも何かをログに記録する必要がありますが、例外を(再)スローすることをお勧めします。

于 2012-12-09T15:44:38.980 に答える