JSP页面查询显示常用模式

背景
1.需要将数据库查询结果在JSP中以列表方式显示
2.在一个良好的J2EE模式中数据库查询一般用DAO实现(DataAccessObject),JSP仅用于显示数据

问题
通过JDBCResultSet可获取查询结果(存在于数据库缓冲区内),但在Statement、Connection关闭后ResultSet即不可用。因此需要一种方式取出所有查询结果并传递至JSP页面。

解决方法一
使用ValueObject。将每条记录均封装成JavaBean对象,把这些对象装入Collection传送给JSP显示。这种方法的缺点是每一种查询都需要定义一个javaclass,并且将记录数据封装成java对象时也需要很多额外的代码。
示例代码:

  1. //查询数据代码
  2. Connectionconn=DBUtil.getConnection();
  3. PreparedStatementpst=null;
  4. ResultSetrs=null;
  5. try{
  6. Stringsql=“selectemp_code,real_namefromt_employeewhereorgan_id=?”;
  7. pst=conn.preparedStatement(sql);
  8. pst.setString(1,“101”);
  9. ResultSetrs=pst.executeQuery();
  10. Listlist=newArrayList();
  11. Employeeemp;
  12. while(rs.next()){
  13. emp=newEmployee();
  14. emp.setReakName(rs.getString(“real_name”));
  15. emp.setEmpCode(rs.getString(“emp_code”));
  16. list.add(emp);
  17. }
  18. returnlist;
  19. }finally{
  20. DBUtil.close(rs,pst,conn);
  21. }
  22. //jsp显示部分代码
  23. <%
  24. ListempList=(List)request.getAttribute(“empList”);
  25. if(empList==null)empList=Collections.EMPTY_LIST;
  26. %>
  27. <tablecellspacing="0"width=”90%”>
  28. <tr><td>代码</td><td>姓名</td></tr>
  29. <%
  30. Employeeemp;
  31. for(inti=0;i<empList.size();i++){
  32. emp=(Employee)empList.get(i);
  33. %>
  34. <tr>
  35. <td><%=emp.getEmpCode()%></td>
  36. <td><%=emp.getRealName()%></td>
  37. </tr>
  38. <%
  39. }//endfor
  40. %>
  41. </table>


解决方法二
遍历ResultSet取出所有数据封装进Collection。
具体做法:
1.生成一个List对象(Listlist=newArrayList())。
2.生成一个Map对象(Mapmap=newHashMap())。使用Map封装一行数据,key为各字段名,value为对应的值。(map.put(“USER_NAME”),rs.getString(“USER_NAME”))
3.将第2步生成的Map对象装入第1步的list对象中(list.add(map))。
4.重复2、3步直到ResultSet遍历完毕
在DBUtil.resultSetToList(ResultSetrs)方法中实现了上述过程(所有列名均使用大写),可参考使用。

示例代码

  1. //查询数据部分代码:
  2. Connectionconn=DBUtil.getConnection();
  3. PreparedStatementpst=null;
  4. ResultSetrs=null;
  5. try{
  6. Stringsql=“selectemp_code,real_namefromt_employeewhereorgan_id=?”;
  7. pst=conn.preparedStatement(sql);
  8. pst.setString(1,“101”);
  9. rs=pst.executeQuery();
  10. Listlist=DBUtil.resultSetToList(ResultSetrs);
  11. returnlist;
  12. }finally{
  13. DBUtil.close(rs,pst,conn);
  14. }
  15. //JSP显示部分代码
  16. <%
  17. ListempList=(List)request.getAttribute(“empList”);
  18. if(empList==null)empList=Collections.EMPTY_LIST;
  19. %>
  20. <tablecellspacing="0"width=”90%”>
  21. <tr><td>代码</td><td>姓名</td></tr>
  22. <%
  23. MapcolMap;
  24. for(inti=0;i<empList.size();i++){
  25. colMap=(Map)empList.get(i);
  26. %>
  27. <tr>
  28. <td><%=colMap.get(“EMP_CODE”)%></td>
  29. <td><%=colMap.get(“REAL_NAME”)%></td>
  30. </tr>
  31. <%
  32. }//endfor
  33. %>
  34. </table>


解决方法三
使用RowSet。
RowSet是JDBC2.0中提供的接口,Oracle对该接口有相应实现,其中很有用的是oracle.jdbc.rowset.OracleCachedRowSet。OracleCachedRowSet实现了ResultSet中的所有方法,但与ResultSet不同的是,OracleCachedRowSet中的数据在Connection关闭后仍然有效。

oracle的rowset实现在
http://otn.oracle.com/software/content.html 的jdbc下载里有,名称是ocrs12.zip

示例代码

  1. //查询数据部分代码:
  2. importjavax.sql.RowSet;
  3. importoracle.jdbc.rowset.OracleCachedRowSet;
  4. Connectionconn=DBUtil.getConnection();
  5. PreparedStatementpst=null;
  6. ResultSetrs=null;
  7. try{……
  8. Stringsql=“selectemp_code,real_namefromt_employeewhereorgan_id=?”;
  9. pst=conn.preparedStatement(sql);
  10. pst.setString(1,“101”);
  11. rs=pst.executeQuery();
  12. OracleCachedRowSetors=newOracleCachedRowSet();
  13. //将ResultSet中的数据封装到RowSet中
  14. ors.populate(rs);
  15. returnors;
  16. }finally{
  17. DBUtil.close(rs,pst,conn);
  18. }
  19. //JSP显示部分代码
  20. <%
  21. javax.sql.RowSetempRS=(javax.sql.RowSet)request.getAttribute(“empRS”);
  22. %>
  23. <tablecellspacing="0"width=”90%”>
  24. <tr><td>代码</td><td>姓名</td></tr>
  25. <%
  26. if(empRS!=null)while(empRS.next()){
  27. %>
  28. <tr>
  29. <td><%=empRS.get(“EMP_CODE”)%></td>
  30. <td><%=empRS.get(“REAL_NAME”)%></td>
  31. </tr>
  32. <%
  33. }//endwhile
  34. %>
  35. </table>


适用场合
方法一使用于定制的查询操作
方法二适用于多条查询语句或需要对查询结果进行处理的情况。
方法三适合于单条查询语句,适用于快速开发。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值