在開發過程中,我們不能將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(字段名)得到值。