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对象时也需要很多额外的代码。
示例代码:
- //查询数据代码
- Connection conn = DBUtil.getConnection();
- PreparedStatement pst = null;
- ResultSet rs = null;
- try{
- String sql=“select emp_code, real_name from t_employee where organ_id=?”;
- pst = conn.preparedStatement(sql);
- pst.setString(1, “101”);
- ResultSet rs = pst.executeQuery();
- List list = new ArrayList();
- Employee emp;
- while (rs.next()){
- emp = new Employee();
- emp.setReakName(rs.getString(“real_name”));
- emp.setEmpCode(rs.getString(“emp_code”));
- …
- list.add(emp);
- }
- return list;
- }finally{
- DBUtil.close(rs, pst ,conn);
- }
- //jsp显示部分代码
- <%
- List empList = (List)request.getAttribute(“empList”);
- if (empList == null) empList = Collections.EMPTY_LIST;
- %>
- …
- <table cellspacing="0" width=”90%”>
- <tr> <td>代码</td> <td>姓名</td> </tr>
- <%
- Employee emp;
- for (int i=0; i< empList.size(); i++){
- emp = (Employee) empList.get(i);
- %>
- <tr>
- <td><%= emp.getEmpCode()%></td>
- <td><%= emp.getRealName()%></td>
- </tr>
- <%
- }// end for
- %>
- </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)方法中实现了上述过程(所有列名均使用大写),可参考使用。
示例代码:
- //查询数据部分代码:
- …
- Connection conn = DBUtil.getConnection();
- PreparedStatement pst = null;
- ResultSet rs = null;
- try{
- String sql=“select emp_code, real_name from t_employee where organ_id=?”;
- pst = conn.preparedStatement(sql);
- pst.setString(1, “101”);
- rs = pst.executeQuery();
- List list = DBUtil. resultSetToList(ResultSet rs);
- return list;
- }finally{
- DBUtil.close(rs, pst ,conn);
- }
- //JSP显示部分代码
- <%
- List empList = (List)request.getAttribute(“empList”);
- if (empList == null) empList = Collections.EMPTY_LIST;
- %>
- …
- <table cellspacing="0" width=”90%”>
- <tr> <td>代码</td> <td>姓名</td> </tr>
- <%
- Map colMap;
- for (int i=0; i< empList.size(); i++){
- colMap = (Map) empList.get(i);
- %>
- <tr>
- <td><%=colMap.get(“EMP_CODE”)%></td>
- <td><%=colMap.get(“REAL_NAME”)%></td>
- </tr>
- <%
- }// end for
- %>
- </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
示例代码:
- //查询数据部分代码:
- import javax.sql.RowSet;
- import oracle.jdbc.rowset.OracleCachedRowSet;
- …
- Connection conn = DBUtil.getConnection();
- PreparedStatement pst = null;
- ResultSet rs = null;
- try{……
- String sql=“select emp_code, real_name from t_employee where organ_id=?”;
- pst = conn.preparedStatement(sql);
- pst.setString(1, “101”);
- rs = pst.executeQuery();
- OracleCachedRowSet ors = newOracleCachedRowSet();
- //将ResultSet中的数据封装到RowSet中
- ors.populate(rs);
- return ors;
- }finally{
- DBUtil.close(rs, pst, conn);
- }
- //JSP显示部分代码
- <%
- javax.sql.RowSet empRS = (javax.sql.RowSet) request.getAttribute(“empRS”);
- %>
- …
- <table cellspacing="0" width=”90%”>
- <tr> <td>代码</td> <td>姓名</td> </tr>
- <%
- if (empRS != null) while (empRS.next() ) {
- %>
- <tr>
- <td><%= empRS.get(“EMP_CODE”)%></td>
- <td><%= empRS.get(“REAL_NAME”)%></td>
- </tr>
- <%
- }// end while
- %>
- </table>
适用场合:
方法一使用于定制的查询操作
方法二适用于多条查询语句或需要对查询结果进行处理的情况。
方法三适合于单条查询语句,适用于快速开发。
相关链接:
如果需要分页显示请参考:
JSP分页技术实现 如果查询结果需要生成WORD或者EXCEL,请参考:
使用jsp实现word、excel格式报表打印附:
DBUtil代码:
- import java.util.List;
- import java.util.ArrayList;
- import java.util.Map;
- import java.util.HashMap;
- import java.util.Properties;
- import java.util.Collections;
- import java.sql.Connection;
- import java.sql.SQLException;
- import java.sql.ResultSet;
- import java.sql.ResultSetMetaData;
- import java.sql.Statement;
- import java.sql.PreparedStatement;
- import javax.naming.Context;
- import javax.naming.InitialContext;
- import javax.naming.NamingException;
- import javax.sql.DataSource;
- public class DBUtil{
- private static final String JDBC_DATA_SOURCE = "java:comp/env/jdbc/DataSource";
- /**
- enableLocalDebug: 是否在本地调试。<br>
- 值为true时如果查找数据源失败则使用DriverManager与数据库建立连接;
- 如果为false则只查找数据源建立数据库连接。
- 默认为false。<br>
- 可通过系统属性jdbc.enable_local_debug=true设置enableLocalDebug为true,启用本地调试:<br>
- 增加JVM parameter: -Djdbc.enable_local_debug=true
- */
- private static boolean enableLocalDebug = false;
- static{
- enableLocalDebug = Boolean.getBoolean ("jdbc.enable_local_debug");
- }
- private static Context ctx = null;
- private static javax.sql.DataSource ds = null;
- private static void initDataSource() throws Exception{
- // Put connection properties in to a hashtable.
- if (ctx == null) {
- ctx = new InitialContext();
- }
- if (ds == null) {
- ds = (javax.sql.DataSource) ctx.lookup(JDBC_DATA_SOURCE);
- }
- }
- /**
- * 查找应用服务器数据源,从数据源中获得数据库连接。<br><br>
- * 在本地调试时如果查找数据源失败并且enableLocalDebug==true
- * 则根据系统属性使用java.sql.DriverManager建立连接。<br>
- * 本地调试时可配置的系统属性如下:<br>
- * <p>
- * #jdbc驱动程序名 <br>
- * jdbc.driver=<i>oracle.jdbc.driver.OracleDriver</i> <br> <br>
- * #数据库连接串<br>
- * jdbc.url=<i>jdbc:oracle:thin:@10.1.1.1:1521:ocrl</i> <br> <br>
- * #数据库用户名<br>
- * jdbc.username=<i>scott</i> <br> <br>
- * #数据库用户密码<br>
- * jdbc.password=<i>tiger</i> <br>
- * </p>
- * 可通过JVM参数设置上述系统属性:<br>
- * -Djdbc.driver=oracle.jdbc.driver.OracleDriver
- * -Djdbc.url=jdbc:oracle:thin:@10.1.1.1:1521:ocrl
- * -Djdbc.username=scott -Djdbc.password=tiger
- * @return Connection
- * @throws NamingException 如果数据源查找失败
- * @throws SQLException 如果建立数据库连接失败
- */
- public static Connection getConnection() throws SQLException{
- try{
- initDataSource();
- return ds.getConnection();
- }catch(SQLException sqle){
- throw sqle;
- }catch(Exception ne){
- if (enableLocalDebug){
- return getTestConn();
- }else{
- throw new RuntimeException(ne.toString());
- }
- }
- }
- //通过DriverManager建立本地测试连接
- private static Connection getTestConn(){
- try {
- String driver = System.getProperty("jdbc.driver");
- System.out.println("jdbc.driver="+driver);
- String url = System.getProperty("jdbc.url");
- System.out.println("jdbc.url="+url);
- String userName = System.getProperty("jdbc.username");
- System.out.println("jdbc.username="+userName);
- String password = System.getProperty("jdbc.password");
- System.out.println("jdbc.password="+password);
- Class.forName(driver).newInstance();
- return java.sql.DriverManager.getConnection(url, userName, password);
- }
- catch (Exception ex) {
- ex.printStackTrace();
- throw new RuntimeException(ex.getMessage());
- }
- }
- /**
- * 将查询结果封装成List。<br>
- * List中元素类型为封装一行数据的Map,Map key为字段名(大写),value为相应字段值
- * @param rs ResultSet
- * @return List
- * @throws java.sql.SQLException
- */
- public static List resultSetToList(ResultSet rs) throws java.sql.SQLException{
- if (rs==null) return Collections.EMPTY_LIST;
- ResultSetMetaData md = rs.getMetaData();
- int columnCount = md.getColumnCount();
- List list = new ArrayList();
- Map rowData;
- while (rs.next()){
- rowData = new HashMap(columnCount);
- for (int i=1; i<=columnCount; i++){
- rowData.put(md.getColumnName(i),rs.getObject(i));
- }
- list.add(rowData);
- }
- return list;
- }
- /**
- * 关闭ResultSet、Statement和Connection
- * @param rs ResultSet to be closed
- * @param stmt Statement or PreparedStatement to be closed
- * @param conn Connection to be closed
- */
- public static void close(ResultSet rs, Statement stmt, Connection conn){
- if (rs != null) try{
- rs.close();
- }catch(java.sql.SQLException ex){
- ex.printStackTrace();
- }
- if (stmt != null) try{
- stmt.close();
- }catch(java.sql.SQLException ex){
- ex.printStackTrace();
- }
- if (conn != null) try{
- conn.close();
- }catch(java.sql.SQLException ex){
- ex.printStackTrace();
- }
- }
- }// end of DBUti
分享到:
相关推荐
【JSP论坛短消息系统详解】 JSP(JavaServer Pages)是Java技术中用于构建动态网页的一种技术。...在本案例中,"jsp论坛短消息"是一个基于JSP开发...提供的源代码能帮助开发者深入理解这些概念,并为自己的项目提供参考。
本资源包含的是“jsp常用模块源代码”,这对于正在学习或从事JSP开发的人员来说是非常有价值的参考资料。 1. **基础组件**: JSP的基础组件包括`<jsp:include>`、`<jsp:forward>`、`<jsp:params>`等标签,它们用于...
6. **JSP与数据库交互**:通过JDBC连接数据库,进行CRUD操作,源代码中可能包括了如何在JSP页面中编写SQL查询和处理结果集的示例。 7. **JSP与JavaBeans**:JavaBeans作为JSP中的业务逻辑组件,可以封装数据和方法...
"JSP常用模块源代码"这个压缩包很可能包含了一些预设的、经过优化的代码片段或组件,方便开发者快速构建Web应用程序。下面我们将深入探讨JSP中的常见模块及其相关知识点。 一、JSP基本元素 1. JSP指令:如`...
在JSP制作的论坛中,JSP页面通常用于展示用户界面,如登录、注册、发帖、回帖等界面,而背后的业务逻辑则由JavaBeans或Servlet来处理。JavaBeans是一种可重用的Java组件,常被用来封装业务逻辑,而Servlet是服务器端...
4. **JSP生命周期与作用域**:源代码可能包含演示JSP页面生命周期的实例,包括初始化、服务、销毁阶段,以及page、request、session和application四种作用域的使用。 5. **MVC(Model-View-Controller)设计模式**...
源代码可能包含使用连接池、SQL查询、预编译语句等数据库操作的实例,展示如何在JSP中进行数据的增删改查。 10. **第14章:MVC框架与JSP** 最后,这一章可能探讨了如Struts、Spring MVC等MVC框架如何与JSP结合,...
【描述】:“很好很强大,下号就能用,源代码和一些常用的框架和jsp页面”说明这个项目不仅包含了完整的源代码,而且具有高度的实用性和可操作性。"下号就能用"可能意味着项目配置好后,只需简单的步骤即可运行。...
1. **JSP基本语法**:源代码会展示如何在JSP页面中嵌入Java代码,包括脚本元素(scriptlet)、表达式(expression)、声明(declaration)和指令(directive)。这有助于初学者理解JSP页面的结构和工作原理。 2. **...
4. **数据持久化**:留言数据通常需要存储在数据库中,因此源代码可能涉及到SQL查询和JDBC(Java Database Connectivity)操作。这可能包括连接数据库、执行增删改查操作以及关闭数据库连接。 5. **MVC模式**:...
2. **Servlet**:JSP页面通常与Servlet配合使用,Servlet负责处理请求和响应,而JSP则专注于显示数据。在教学网站中,Servlet可能用于处理用户登录、注册、提交作业等操作。 3. **JDBC(Java Database Connectivity...
本资源是 jsp 实用教程(第二版)的源代码,共分为 10 章,涵盖了 JSP 的基础知识、语法、内置对象、Javabean、文件操作、数据库操作、JavaServlet、MVC 设计模式、XML 等重要内容。每一章都配备了大量的例题,旨在...
1. **JSTL(JSP Standard Tag Library)**:提供一套标准标签库,简化JSP页面的编写,如`<c:forEach>`用于遍历集合,`<fmt:formatDate>`用于格式化日期。 2. **EL(Expression Language)**:JSP表达式语言,用于在...
【标题】中的“用jsp做的MVC模式的用户登录程序的源代码”表明这是一个基于Java Server Pages(JSP)技术实现的、遵循Model-View-Controller(MVC)设计模式的用户登录系统。MVC模式是软件工程中常用的一种架构模式...
第二章讲解了JSP页面的基本结构和常用的JSP标记,如指令、动作和脚本元素,这些都是构建JSP页面的基础。 第三章讨论了JSP的内置对象,如request、response、session、application等,它们是JSP开发中不可或缺的部分...
《JSP教师档案管理系统》是一个基于Java服务器页面(JSP)技术开发的教育管理软件,主要功能...通过研究源代码和阅读论文,开发者可以深入理解如何利用JSP、MVC模式、数据库技术和前端技术构建一个完整的管理信息系统。
这个压缩包中的"jsp"文件夹可能包含了所有的JSP页面,每个页面都对应着网站的一个部分。例如,index.jsp通常是首页,login.jsp处理用户登录,admin.jsp可能用于管理员界面等。通过阅读和分析这些JSP文件,我们可以...
在学习这个教程的过程中,你可以通过解压提供的源代码,逐步分析每个示例,理解它们如何实现特定功能,比如用户登录、注册、数据显示等。此外,通过动手实践,你可以熟悉开发环境的搭建,如Tomcat服务器的配置,以及...