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 DBUtil

文章标题链接

Struts 学习笔记1 -Struts Framework 概览
Struts 学习笔记2 -ActionServlet深入探讨 
J2EE Server下的第一个EJB程序(图文进阶篇)
Java程序员的推荐阅读书籍
编写php的extension实例 
“茴字有六种写法”式的C语言笔试题 
Java 程序员面试题目(经典)^_^
巧用注册表保安全
如何修复注册表!
C++ 开发常用工具“群英会”
特酷的打开窗口方法
网页制作中如何改变鼠标的形状!
最详细的计算机命令
最详细的SQL注入相关的命令整理
如何人工给电脑加速?(经典知识) 
关于六种Java异常处理程序的陋习
jsp乱码解决大全
常用的Eclipse快捷键
一个有趣的JAVASCRIPT代码!
安装和配置BEA WorkShop JSP Editor
BEA Workshop™ for JSF 3.0
JavaScript技术讲座-使用内部对象系统
35种网站常用Javascript技巧
.NET中获取电脑名、IP及用户名方法 
.NET中Form之间的互相调用 
.NET下基于API封装的DirectUIHWND窗体访问 
JSP页面查询显示常用模式

JSP页面查询显示常用模式相关推荐

  1. JSP页面查询显示常用模式 (附源代码)

    JSP页面查询显示常用模式 title: JSP页面查询显示常用模式 author: evan email:  evan_zhao@hotmail.com      背景: 1.    需要将数据库查 ...

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

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

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

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

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

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

  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. jsp页面在线显示pdf文件

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

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

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

  9. jsp页面中显示word/excel文档方法

    方法一 iframe直接引入excel文件 <form id="form1" runat="server"><iframe src=" ...

最新文章

  1. 韩顺平循序渐进学java 第10.11讲 继承.重载.覆盖
  2. 如何更改Inactive object的ownership
  3. 大数据_Flink_数据处理_运行时架构3_yarn上作业提交流程---Flink工作笔记0018
  4. ubuntu 命令记忆
  5. 三元运算符和if else_PHP If-Else,Switch Case和速记三元运算符示例
  6. string-indexOf、substring、split
  7. Python 06 编码
  8. Python学习笔记之 高级变量类型 列表,元组,字典,字符串的相关常用 操作
  9. Innodb 的事物隔离级别实现原理(一)
  10. python加redis使用教程_python操作Redis入门教程①
  11. pdca管理循环基本主张_两个经典的循环管理法:PDCA SDCA
  12. 一篇博客带你入门shiro
  13. JAVA实现邮件抄送,密送,多个附件发送
  14. 【DDD落地实践系列】DDD领域驱动设计如何进行工程化落地
  15. 中英文之间的空格处理
  16. unity 3d开发的大型网络游戏
  17. 计算机键盘快速指南,如何练习盲打(快速学会键盘盲打技巧)
  18. 工作用哪个邮箱好用?好用的办公邮箱让你放假无烦恼
  19. 求真值表,主析取范式,主合取范式
  20. KEIL、uVision、RealView、MDK、KEIL C51区别比较

热门文章

  1. knn 识别自己的手写体
  2. QRCode使用(生成二维码)
  3. 基于USB总线的高炮火控计算机测试系统设计
  4. oracle修改数据库表字段
  5. openwrt配置内核驱动_为斐讯K2P编译OpenWRT LEDE,并启用mtk闭源wifi驱动及H3C认证
  6. python 实现计时器(不同实现方式)
  7. 今日分享主题:关于抖音上抖币充值的介绍
  8. 北乔峰南慕容:懂球帝与虎扑体育的“武功”较量
  9. JSR303以及常见Validator实现
  10. 学计算机去华农好还是广工好,广东工业大学,华南农业大学哪个间学校好