在開發過程中,我們不能將ResultSet對象作為方法的返回值,因為Connection連接一旦關閉,在此連接上的會話和在會話上的結果集也將會自動關閉,而Result對象則不會發生這種現象,所以在查詢時盡量以Result對象作為方法返回值。
import javax.servlet.jsp.jstl.sql.Result;
import javax.servlet.jsp.jstl.sql.ResultSupport;
ResultSet rs = executeQuery(sql, params);
Result result = ResultSupport.toResult(rs);
if(result!=null && result.getRowCount()!=0){
for(int i=0;i<result.getRowCount();i++){
Map row = result.getRows()[i];
System.out.println(row.get("字段1")+" "+row.get("字段2"));
}
}
當得到ResultSet結果集后,我們可以使用ResultSupport類的靜態方法toResult(ResultSet對象),將結果集ResultSet類型轉化為Result類型。
Result對象.getRowCount()方法返回所有行數。
Result對象.getRows()方法返回所有的數據行,返回類型為SortedMap[]數組,可以使用循環遍歷這個數組,每次得到一個Map類型的變量,再使用row.get(字段名)得到值。
