使用Result代替ResultSet作為方法返回值


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM