JSP页面查询显示常用模式
title: JSP页面查询显示常用模式

author: evan

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

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

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

  1. //查询数据代码
  2. Connection conn = DBUtil.getConnection();
  3. PreparedStatement pst = null;
  4. ResultSet rs = null;
  5. try{
  6. String sql=“select emp_code, real_name from t_employee where organ_id=?”;
  7. pst = conn.preparedStatement(sql);
  8. pst.setString(1, “101”);
  9. ResultSet rs = pst.executeQuery();
  10. List list = new ArrayList();
  11. Employee emp;
  12. while (rs.next()){
  13. emp = new Employee();
  14. emp.setReakName(rs.getString(“real_name”));
  15. emp.setEmpCode(rs.getString(“emp_code”));
  16. list.add(emp);
  17. }
  18. return list;
  19. }finally{
  20. DBUtil.close(rs, pst ,conn);
  21. }
  22. //jsp显示部分代码
  23. <%
  24. List empList = (List)request.getAttribute(“empList”);
  25. if (empList == null) empList = Collections.EMPTY_LIST;
  26. %>
  27. <table  cellspacing="0" width=”90%”>
  28. <tr>  <td>代码</td> <td>姓名</td>  </tr>
  29. <%
  30. Employee emp;
  31. for (int i=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. }// end for
  40. %>
  41. </table>

解决方法二
    遍历ResultSet取出所有数据封装进Collection。
具体做法:
1.    生成一个List对象(List list = new ArrayList() )。
2.    生成一个Map对象(Map map = new HashMap() )。使用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(ResultSet rs)方法中实现了上述过程(所有列名均使用大写),可参考使用。

示例代码

  1. //查询数据部分代码:
  2. Connection conn = DBUtil.getConnection();
  3. PreparedStatement pst = null;
  4. ResultSet rs = null;
  5. try{
  6. String sql=“select emp_code, real_name from t_employee where organ_id=?”;
  7. pst = conn.preparedStatement(sql);
  8. pst.setString(1, “101”);
  9. rs = pst.executeQuery();
  10. List list = DBUtil. resultSetToList(ResultSet rs);
  11. return list;
  12. }finally{
  13. DBUtil.close(rs, pst ,conn);
  14. }
  15. //JSP显示部分代码
  16. <%
  17. List empList = (List)request.getAttribute(“empList”);
  18. if (empList == null) empList = Collections.EMPTY_LIST;
  19. %>
  20. <table  cellspacing="0" width=”90%”>
  21. <tr>  <td>代码</td> <td>姓名</td>  </tr>
  22. <%
  23. Map colMap;
  24. for (int i=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. }// end for
  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. import javax.sql.RowSet;
  3. import oracle.jdbc.rowset.OracleCachedRowSet;
  4. Connection conn = DBUtil.getConnection();
  5. PreparedStatement pst = null;
  6. ResultSet rs = null;
  7. try{……
  8. String sql=“select emp_code, real_name from t_employee where organ_id=?”;
  9. pst = conn.preparedStatement(sql);
  10. pst.setString(1, “101”);
  11. rs = pst.executeQuery();
  12. OracleCachedRowSet ors = newOracleCachedRowSet();
  13. //将ResultSet中的数据封装到RowSet中
  14. ors.populate(rs);
  15. return ors;
  16. }finally{
  17. DBUtil.close(rs, pst, conn);
  18. }
  19. //JSP显示部分代码
  20. <%
  21. javax.sql.RowSet empRS = (javax.sql.RowSet) request.getAttribute(“empRS”);
  22. %>
  23. <table  cellspacing="0" width=”90%”>
  24. <tr>  <td>代码</td> <td>姓名</td>  </tr>
  25. <%
  26. if (empRS != nullwhile (empRS.next() ) {
  27. %>
  28. <tr>
  29. <td><%= empRS.get(“EMP_CODE”)%></td>
  30. <td><%= empRS.get(“REAL_NAME”)%></td>
  31. </tr>
  32. <%
  33. }// end while
  34. %>
  35. </table>

适用场合
  方法一使用于定制的查询操作
  方法二适用于多条查询语句或需要对查询结果进行处理的情况。
  方法三适合于单条查询语句,适用于快速开发。

相关链接
    如果需要分页显示请参考: JSP分页技术实现
    如果查询结果需要生成WORD或者EXCEL,请参考: 使用jsp实现word、excel格式报表打印

附: DBUtil代码

  1. import java.util.List;
  2. import java.util.ArrayList;
  3. import java.util.Map;
  4. import java.util.HashMap;
  5. import java.util.Properties;
  6. import java.util.Collections;
  7. import java.sql.Connection;
  8. import java.sql.SQLException;
  9. import java.sql.ResultSet;
  10. import java.sql.ResultSetMetaData;
  11. import java.sql.Statement;
  12. import java.sql.PreparedStatement;
  13. import javax.naming.Context;
  14. import javax.naming.InitialContext;
  15. import javax.naming.NamingException;
  16. import javax.sql.DataSource;
  17. public class DBUtil{
  18. private static final String JDBC_DATA_SOURCE = "java:comp/env/jdbc/DataSource";
  19. /**
  20.      enableLocalDebug: 是否在本地调试。<br>
  21.      值为true时如果查找数据源失败则使用DriverManager与数据库建立连接;
  22.      如果为false则只查找数据源建立数据库连接。
  23.      默认为false。<br>
  24.      可通过系统属性jdbc.enable_local_debug=true设置enableLocalDebug为true,启用本地调试:<br>
  25.      增加JVM parameter: -Djdbc.enable_local_debug=true
  26.      */
  27. private static boolean enableLocalDebug = false;
  28. static{
  29. enableLocalDebug = Boolean.getBoolean ("jdbc.enable_local_debug");
  30. }
  31. private static Context ctx = null;
  32. private static javax.sql.DataSource ds = null;
  33. private static void initDataSource() throws Exception{
  34. // Put connection properties in to a hashtable.
  35. if (ctx == null) {
  36. ctx = new InitialContext();
  37. }
  38. if (ds == null) {
  39. ds = (javax.sql.DataSource) ctx.lookup(JDBC_DATA_SOURCE);
  40. }
  41. }
  42. /**
  43.      * 查找应用服务器数据源,从数据源中获得数据库连接。<br><br>
  44.      * 在本地调试时如果查找数据源失败并且enableLocalDebug==true
  45.      * 则根据系统属性使用java.sql.DriverManager建立连接。<br>
  46.      * 本地调试时可配置的系统属性如下:<br>
  47.      * <p>
  48.      *     #jdbc驱动程序名 <br>
  49.      *     jdbc.driver=<i>oracle.jdbc.driver.OracleDriver</i> <br> <br>
  50.      *     #数据库连接串<br>
  51.      *     jdbc.url=<i>jdbc:oracle:thin:@10.1.1.1:1521:ocrl</i> <br> <br>
  52.      *     #数据库用户名<br>
  53.      *     jdbc.username=<i>scott</i> <br> <br>
  54.      *     #数据库用户密码<br>
  55.      *     jdbc.password=<i>tiger</i> <br>
  56.      * </p>
  57.      * 可通过JVM参数设置上述系统属性:<br>
  58.      * -Djdbc.driver=oracle.jdbc.driver.OracleDriver 
  59.      *  -Djdbc.url=jdbc:oracle:thin:@10.1.1.1:1521:ocrl
  60.      *  -Djdbc.username=scott -Djdbc.password=tiger
  61.      * @return Connection
  62.      * @throws NamingException 如果数据源查找失败
  63.      * @throws SQLException 如果建立数据库连接失败
  64.      */
  65. public static Connection getConnection() throws  SQLException{
  66. try{
  67. initDataSource();
  68. return ds.getConnection();
  69. }catch(SQLException sqle){
  70. throw sqle;
  71. }catch(Exception ne){
  72. if (enableLocalDebug){
  73. return getTestConn();
  74. }else{
  75. throw new RuntimeException(ne.toString());
  76. }
  77. }
  78. }
  79. //通过DriverManager建立本地测试连接
  80. private static Connection getTestConn(){
  81. try {
  82. String driver = System.getProperty("jdbc.driver");
  83. System.out.println("jdbc.driver="+driver);
  84. String url = System.getProperty("jdbc.url");
  85. System.out.println("jdbc.url="+url);
  86. String userName = System.getProperty("jdbc.username");
  87. System.out.println("jdbc.username="+userName);
  88. String password = System.getProperty("jdbc.password");
  89. System.out.println("jdbc.password="+password);
  90. Class.forName(driver).newInstance();
  91. return java.sql.DriverManager.getConnection(url, userName, password);
  92. }
  93. catch (Exception ex) {
  94. ex.printStackTrace();
  95. throw new RuntimeException(ex.getMessage());
  96. }
  97. }
  98. /**
  99.      * 将查询结果封装成List。<br>
  100.      * List中元素类型为封装一行数据的Map,Map key为字段名(大写),value为相应字段值
  101.      * @param rs ResultSet
  102.      * @return List
  103.      * @throws java.sql.SQLException
  104.      */
  105. public static List resultSetToList(ResultSet rs) throws java.sql.SQLException{
  106. if (rs==nullreturn Collections.EMPTY_LIST;
  107. ResultSetMetaData md = rs.getMetaData();
  108. int columnCount = md.getColumnCount();
  109. List list = new ArrayList();
  110. Map rowData;
  111. while (rs.next()){
  112. rowData = new HashMap(columnCount);
  113. for (int i=1; i<=columnCount; i++){
  114. rowData.put(md.getColumnName(i),rs.getObject(i));
  115. }
  116. list.add(rowData);
  117. }
  118. return list;
  119. }
  120. /**
  121.      * 关闭ResultSet、Statement和Connection
  122.      * @param rs ResultSet to be closed
  123.      * @param stmt Statement or PreparedStatement  to be closed
  124.      * @param conn Connection  to be closed
  125.      */
  126. public static void close(ResultSet rs, Statement stmt, Connection conn){
  127. if (rs != nulltry{
  128. rs.close();
  129. }catch(java.sql.SQLException ex){
  130. ex.printStackTrace();
  131. }
  132. if (stmt != nulltry{
  133. stmt.close();
  134. }catch(java.sql.SQLException ex){
  135. ex.printStackTrace();
  136. }
  137. if (conn != nulltry{
  138. conn.close();
  139. }catch(java.sql.SQLException ex){
  140. ex.printStackTrace();
  141. }
  142. }
  143. }// end of DBUti

JSP页面查询显示常用模式 (附源代码)相关推荐

  1. JSP页面查询显示常用模式

    title: JSP页面查询显示常用模式 author: evan email:  evan_zhao@hotmail.com      背景: 1.    需要将数据库查询结果在JSP中以列表方式显 ...

  2. jsp空白页面传html代码,echarts在HTML里测试一般,在jsp页面不显示,而且还把整个页面变成空白...

    echarts在HTML里测试正常,在jsp页面不显示,而且还把整个页面变成空白 echarts在HTML里测试正常,在jsp页面不显示,而且还把整个页面变成空白,请大神帮忙,急,在线等 Create ...

  3. 关于ECharts在jsp页面无法显示的问题

    关于ECharts在jsp页面无法显示 问题一,HTML5到底能不能在jsp页面显示 html5是html标准,属于w3c,是html标准的延伸,所有浏览器展示页面基本都是html的.所以我还是不太明 ...

  4. java错误页面显示错误信息_Struts2在JSP页面中显示错误信息和提示信息的方法

    Struts2在JSP页面中显示错误信息和提示信息的方法主要有以下四种. 注意:以下四种方法均需要使Action类继承ActionSupport类. 一.域级错误信息 ①重写Action中的valid ...

  5. JSP页面分页显示数据

    一.源代码(这里以一个Java web的留言板项目为例): 1.Dao层操作数据库的方法(MessageDao.java) 设置每页显示的最大留言条数: private final int MAX_S ...

  6. 在JSP页面中显示List集合·

    这是Servlet种获取数据库集合的代码 //通过querryName来查询数据库,将结果放在all里面,Users是一个JavaBean List <Users>all = DAOFac ...

  7. javabean+servlet+JSP页面做购物网站 (附效果图+源码)

    一个简单的jsp购物网站 概要 需求 用到的技术 效果图 登录页 登陆结果 购物页 消费记录页 管理用户信息和商品信息 数据库格式 踩过的坑 jdbc进行数据库操作 java动作指令结合jsp脚本 j ...

  8. jsp页面在线显示pdf文件

    实现功能 知识库系统中存在一个附件就是一个知识,当全文搜索到这个附件知识的时候需要能在线查看这个知识也就是附件里的文章内容.(如果不是pdf格式的文档,我们这边是先将不同格式的附件转成PDF格式) 实 ...

  9. 关于springmvc 只能在index.jsp页面显示图片的处理办法jsp页面无法显示图片

    首先,已经配置好了mvc对静态资源的处理 只有index,jsp可以显示图片 其他页面同样的代码则不显示 后来折腾了半天,发现 index是static的父目录的级别文件 可以向下访问 但是其他的js ...

最新文章

  1. [WebDev]Web 开发与设计师速查手册大全
  2. zigbee学习之路(二)点亮LED
  3. 全球及中国香蕉连接器行业投资商机与前景趋势展望报告2022版
  4. PHP Parse error: parse error, unexpected T_OBJECT_OPERATOR
  5. 使用适用于Java 2的AWS开发工具包的AWS DynamoDB版本字段
  6. 13结构型模式之桥接模式
  7. Java中常见RuntimeException与其他异常表及Exception逻辑关系详解
  8. MS SQL的某一数据库成了Single User模式
  9. python:读取mat文件
  10. 例2.11 FatMouse' Trade - 九度教程第21题(贪心算法)
  11. Linux中使用SSH服务远程连接Linux系统
  12. 上证指数ARIMA模型预测(R软件)
  13. C/C++编程:#pragma once用法总结
  14. 2022-2028年中国燃气轮机行业市场专项调研及投资前景研究报告
  15. 全球 AI 人工智能报告 —— 来自乌镇互联网大会
  16. python int() round() floor()函数的比较
  17. 网络故障和网络诊断工具(1.0)
  18. CheckBox属性
  19. 英语每日阅读---2、越来越多人反对人工智能参战
  20. QPBOC之GPO(一):CVM处理

热门文章

  1. C语言LCD1602液晶实验报告,LCD1602液晶显示实验报告.doc
  2. 微服务构建思路与方法论
  3. epoll使用详解:epoll_create、epoll_ctl、epoll_wait、close
  4. 浏览器下载软件时,默认是用迅雷下载,如何取消?
  5. 原创 | 2020年数据科学与大数据技术专业填报指南(附院校及专业介绍)
  6. linux http连接超时时间设置,Linux 下 HTTP连接超时
  7. sourcetree的使用方法
  8. [SUCCESS]Fedora install Nvidia-driver
  9. Delphi SM2/SM4国密算法
  10. C#环形缓冲区(队列)完全实现(转)