[英]Prepared Statement seems to return always null in java servlet
我正在開發一個項目,用戶應該在表單中填寫他想要的標准,然后根據這些標准,servlet從數據庫返回相應的結果; 我正在使用mysql服務器。 我的問題是我用過的Prepared Statement(因為用戶可以用可變數量的標准搜索)總是返回null,所以我得到一個
Exception: null java.lang.NullPointerException at
Servlet_GrowerResults.doGet(Servlet_GrowerResults.java:102)
這是GetData類中的方法fetchGrowers,它將ResultSet返回給Servlet_GrowerResults
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);
}
這里是Exception指向的行。 更具體地說,第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
我可以看到確實存在問題,因為在進入第二個區域之前它打印第一個區域,因為它應該做,然后Exception!
我試過sql查詢直接到mysql服務器,它的工作原理,我只是找不到問題! 我們將非常感謝您的回答,謝謝。
您需要按順序設置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);
我打賭這里吞下了一個SQLException:
catch(Exception e9){
errorMessage = "Error while getting all growers from database!<br>" + e9.getMessage();
return null;
}
修復此問題,以記錄發生的異常或重新拋出適當的更高級別異常。 在出錯時靜默返回null 總是一個壞主意。
當您添加發布的帖子時,我們可以嘗試幫助您跟蹤原因。
fetchGrowers有一個次優的錯誤處理。 您只是捕獲異常,創建一個未使用的消息並返回null,這將導致以后的nullpointer,我們不知道為什么。 你應該至少記錄一些東西,更好地(重新)拋出異常。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.