`

JSP页面查询显示常用模式

 
阅读更多

全文转载自:http://pharaohsprince.iteye.com/blog/74970,所有权归原作者所有

 

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

    
背景
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.       …
  17.       list.add(emp);
  18.     }
  19.     return list;
  20.   }finally{
  21.     DBUtil.close(rs, pst ,conn);
  22.   }


  23. //jsp显示部分代码
  24. <%
  25.   List empList = (List)request.getAttribute(“empList”);
  26.   if (empList == null) empList = Collections.EMPTY_LIST;
  27. %>
  28. <table  cellspacing="0" width=”90%”>
  29.     <tr>  <td>代码</td> <td>姓名</td>  </tr>
  30. <%
  31.   Employee emp;
  32.   for (int i=0; i< empList.size(); i++){
  33.     emp = (Employee) empList.get(i);
  34. %>
  35.     <tr>  
  36.       <td><%= emp.getEmpCode()%></td> 
  37.       <td><%= emp.getRealName()%></td>  
  38.     </tr>
  39. <%
  40.   }// end for
  41. %>
  42. </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.   …
  3.   Connection conn = DBUtil.getConnection();
  4.   PreparedStatement pst = null;
  5.   ResultSet rs = null;
  6.   try{
  7.     String sql=“select emp_code, real_name from t_employee where organ_id=?”;
  8.     pst = conn.preparedStatement(sql);
  9.     pst.setString(1, “101”);
  10.     rs = pst.executeQuery();
  11.     List list = DBUtil. resultSetToList(ResultSet rs);
  12.     return list;
  13.   }finally{
  14.     DBUtil.close(rs, pst ,conn);
  15.   }



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


  20. //JSP显示部分代码
  21. <%
  22.   javax.sql.RowSet empRS = (javax.sql.RowSet) request.getAttribute(“empRS”);
  23. %>
  24. <table  cellspacing="0" width=”90%”>
  25.     <tr>  <td>代码</td> <td>姓名</td>  </tr>
  26. <%
  27.   if (empRS != nullwhile (empRS.next() ) {
  28. %>
  29.   <tr>  
  30.     <td><%= empRS.get(“EMP_CODE”)%></td> 
  31.     <td><%= empRS.get(“REAL_NAME”)%></td>  
  32.   </tr>
  33. <%
  34.   }// end while
  35. %>
  36. </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页面,连接数据库实现增删改查

    JSP页面通常会提供一个搜索表单,用户输入查询条件,然后后台的Java代码根据这些条件构造SQL查询语句,从数据库获取结果,并在页面上显示出来。 在这个过程中,我们还需要考虑安全性问题,比如防止SQL注入攻击,...

    servlet读取数据库代码到jsp页面表格示例

    在本例中,Servlet负责与数据库交互,获取数据并传递给JSP页面。 2. **JSP (JavaServer Pages)**: JSP是动态网页技术,用于创建HTML或XML等格式的响应。它将业务逻辑和表现层分开,使开发者能够更专注于页面设计。...

    jsp的页面设置

    **JSP(JavaServer Pages...`page`指令用于配置整个JSP页面的属性,如指定语言、导入包等;`include`指令用于在多个页面间共享内容;`taglib`指令引入自定义标签库。 ```jsp ; charset=UTF-8" pageEncoding="UTF-8"%&gt; ...

    jsp常用模块源代码

    JSTL是一套标准的标签库,包含核心、SQL、XML、JDBC等标签,可以替代脚本片段,使JSP页面更符合MVC模式。 7. **JSP 2.0及更高版本的特性**: - `page指令`中的`isThreadSafe`属性,默认为true,表示JSP页面是线程...

    jsp页面

    **JSP页面详解** JavaServer Pages(JSP)是一种基于Java技术的动态网页开发标准,由Sun Microsystems(现已被Oracle公司收购)在1999年推出,旨在简化Web应用程序的开发。JSP允许开发者将静态HTML内容和动态Java...

    web(jsp)教务查询

    MVC模式(Model-View-Controller)是Web开发中常用的设计模式,其中模型处理数据,视图负责显示,控制器接收用户请求并协调模型和视图。 项目结构中的`.classpath`、`.mymetadata`、`.project`和`.myeclipse`文件是...

    jsp中的 mvc模式开发 实例

    2. **视图(View)**:JSP页面扮演视图的角色,显示数据。通过EL(Expression Language)和JSTL(JavaServer Pages Standard Tag Library)标签,可以从模型中获取数据并展示在页面上。 3. **控制器(Controller)*...

    jsp公交车查询系统

    2. **Servlet**:在JSP公交车查询系统中,JSP页面通常会转换成Servlet来执行。Servlet是Java Web应用中的服务器端组件,负责处理HTTP请求并生成响应。当用户发起请求时,JSP会被转换为Servlet实例,处理请求后返回...

    jsp页面用jstl取值

    本篇文章将深入探讨如何在JSP页面中利用JSTL来读取Service层传递过来的数据。 首先,我们需要理解JSP和JSTL的基本概念。JSP是一种服务器端的技术,它允许开发者在HTML中嵌入Java代码,以生成动态网页内容。然而,...

    mvc模式jsp计算器

    7. JSP页面接收到结果后,更新显示在显示屏上的值。 **文件名称列表分析**: 虽然未提供完整的文件列表,但可以推测"calcu"可能代表"calculator"的缩写。在实际的项目中,我们可能会有以下文件: - `calculation....

    【原创】struts+mysql+jsp 分页

    总结来说,"struts+mysql+jsp 分页"这个主题涉及到Struts框架中Action类的设计、MySQL数据库的分页查询以及JSP页面的动态渲染。通过合理的代码组织和利用MVC模式,可以实现高效、灵活的分页功能。在实际开发中,...

    火车票查询jsp编码

    开发者需要在JSP中定义处理这些请求的逻辑,例如使用`&lt;form&gt;`标签和`action`属性来指定处理请求的JSP页面。 7. **响应处理**:服务器处理完请求后,会返回结果给客户端。这可能涉及到动态生成HTML内容,或者通过...

    jsp求职招聘网站jsp+servlet+mysql模式

    JSP页面在服务器上被编译成Servlet,然后执行。 2. **Servlet技术**: Servlet是Java中的一个接口,用于处理HTTP请求。在本项目中,Servlet用于接收用户请求,执行业务逻辑,并返回响应。Servlet与JSP配合,可以...

    jsp的常用特效和js的常用特效

    通过使用`&lt;%= %&gt;`表达式或者`&lt;jsp:expression&gt;`标签,开发者可以轻松地在页面上显示数据库查询结果或其他动态信息。 2. **表单处理**:JSP可以处理用户提交的表单数据。通过`&lt;form&gt;`标签和动作方法(如GET或POST)...

    jsp中model2模式的开发小应用

    在`model2_demo`压缩包中,应该包含了一个完整的MyEclipse项目,包括Java源代码、JSP页面、配置文件等,可以作为学习和实践Model2模式的参考。 总的来说,Model2模式在JSP中的应用使得Web应用的结构更加清晰,降低...

    JSP常用模块源代码

    EL是一种轻量级的脚本语言,用于在JSP页面中读取和设置JavaBean或其他作用域内的对象属性。例如`${bean.property}`。 四、JSTL(JSP Standard Tag Library) JSTL是一组标准的标签库,提供了许多实用的功能,如条件...

    MyEclipse使用JDBC查询数据库(MVC模式)

    queryAll.jsp是顺序查询的JSP页面,使用JSTL的forEach标签遍历JavaBean的数据,显示学生信息。 知识点11:模糊查询 searchByName.jsp是模糊查询的JSP页面,提供了一个表单,用于输入学生姓名,然后提交到Service...

    jsp公交查询系统源码(java开发)

    【标题】:“jsp公交查询系统源码(java开发)”是指一个使用Java语言开发的公交查询系统的源代码,主要基于JSP(Java Server Pages)技术实现。这样的系统旨在为用户提供方便快捷的城市公交线路查询功能。 【描述...

Global site tag (gtag.js) - Google Analytics