在开发过程中,我们不能将ResultSet对象作为方法的返回值,因为Connection连接一旦关闭,在此连接上的会话和在会话上的结果集也将会自动关闭,而Result对象则不会发生这种现象,所以在查询时尽量以Result对象作为方法返回值。
1
2
3
4
5
6
7
8
9
10
11
12
|
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(字段名)得到值。
转载于:https://www.cnblogs.com/zzlp/p/5120176.html