- 浏览: 31635 次
- 性别:
- 来自: 天津
最近访客 更多访客>>
最新评论
-
confident_f:
这个链接打不开了,可有其他途径找到这个材料
Spring Security-2.0入门教程 -
阳光晒晒:
看不到把传送门发出来
风雨过后见彩虹
JSP页面查询显示常用模式 背景:
1. 需要将数据库查询结果在JSP中以列表方式显示
2. 在一个良好的J2EE模式中数据库查询一般用DAO实现(Data Access Object), JSP仅用于显示数据
问题:
通过JDBC ResultSet可获取查询结果(存在于数据库缓冲区内),但在Statement、Connection关闭后ResultSet即不可用。因此需要一种方式取出所有查询结果并传递至JSP页面。
解决方法一:
使用Value Object。将每条记录均封装成JavaBean对象,如:http://www.bt285.cn 把这些对象装入Collection传送给JSP显示。这种方法的缺点是每一种查询都需要定义一个java class,并且将记录数据封装成java对象时也需要很多额外的代码。
示例代码:
解决方法二:
遍历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)方法中实现了上述过程(所有列名均使用大写),可参考使用。
示例代码:
解决方法三:
使用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
示例代码:
适用场合:
方法一使用于定制的查询操作
方法二适用于多条查询语句或需要对查询结果进行处理的情况。
方法三适合于单条查询语句,适用于快速开发。 posted width = "1" height = "1" />
1. 需要将数据库查询结果在JSP中以列表方式显示
2. 在一个良好的J2EE模式中数据库查询一般用DAO实现(Data Access Object), JSP仅用于显示数据
问题:
通过JDBC ResultSet可获取查询结果(存在于数据库缓冲区内),但在Statement、Connection关闭后ResultSet即不可用。因此需要一种方式取出所有查询结果并传递至JSP页面。
解决方法一:
使用Value Object。将每条记录均封装成JavaBean对象,如:http://www.bt285.cn 把这些对象装入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> http://www.5a520.cn 小说520网 代码</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> http://www.feng123.com 蜂蜜 代码</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>
适用场合:
方法一使用于定制的查询操作
方法二适用于多条查询语句或需要对查询结果进行处理的情况。
方法三适合于单条查询语句,适用于快速开发。 posted width = "1" height = "1" />
发表评论
-
关于调整部分政府性基金有关政策的通知
2019-07-15 20:42 392摘要: 允许抵免的投资是指试点企业当年实际发生的,独立举办或 ... -
我最近的工作
2009-08-21 11:47 7801:浪潮服务器 曙光服务器 尖锐湿疣等关键字的排名 2:淘宝上 ... -
09游记·夏:天边的云
2009-07-21 17:08 769[img=560,309]http://hiphoto ... -
玩轮滑的人们
2009-07-05 17:08 964轮滑之所以深受大众的 ... -
蜜月滇藏游(8)香格里拉-美的绚烂美的妖娆
2009-06-27 17:08 798中国国家地理对于广义的香格里拉定义是:从西藏东南部林芝地区到滇 ... -
印尼的天空很归属。
2009-06-19 17:08 1003在印度尼西亚没有高楼 ... -
Tapestry最新版5.1.0.5教程(二)续
2009-06-14 08:13 898Tapestry最新版5.1.0.5教程(二)续 ... -
spring junit 测试
2009-06-14 08:01 1351spring junit 测试 Poste ... -
TWaver3.0 SVG WebRadar Chart
2009-06-14 07:58 1013TWaver3.0 SVG WebRadar Chart ... -
Duke's Choice Award 2009(译)
2009-06-14 07:55 726Duke's Choice Award 2009(译) ... -
环境无关的环境
2009-06-14 07:45 791环境无关的环境 Pos ... -
唯美颐和园:中国传统文化的胜景
2009-06-11 17:08 878标帜建筑昆明湖前的万寿山上的佛香阁十六孔桥石栏水景塔昆明湖佛香 ... -
风雨过后见彩虹
2009-06-10 15:51 822~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ... -
RAP的超酷应用系统:CAS PIA
2009-06-09 07:40 923RAP的超酷应用系统:CAS PIA 下面是基于RA ... -
Tapestry最新版5.1.0.5教程(三)
2009-06-06 09:37 1099Tapestry最新版5.1.0.5教程(三) P ... -
Spring Security-2.0入门教程
2009-06-05 07:22 1356Spring Security-2.0入门教程 欢迎 ... -
(Multi-stage Continuous Integration)多阶段持续集成
2009-06-04 06:44 579BlogJava 首页 新随笔 联系 聚合 ... -
Linux批量替换文件内容
2009-06-02 08:23 2153Linux批量替换文件内容 Posted widt ... -
ubuntu 8.10下手动安装vmvare tools
2009-06-02 08:20 1340ubuntu 8.10下手动安装vmvare tools ... -
webservice 视频教程 Spring+xfire 整合
2009-06-02 08:17 4739webservice 视频教程 Spring+xfire 整合 ...
相关推荐
JSP页面通常会提供一个搜索表单,用户输入查询条件,然后后台的Java代码根据这些条件构造SQL查询语句,从数据库获取结果,并在页面上显示出来。 在这个过程中,我们还需要考虑安全性问题,比如防止SQL注入攻击,...
在本例中,Servlet负责与数据库交互,获取数据并传递给JSP页面。 2. **JSP (JavaServer Pages)**: JSP是动态网页技术,用于创建HTML或XML等格式的响应。它将业务逻辑和表现层分开,使开发者能够更专注于页面设计。...
**JSP(JavaServer Pages...`page`指令用于配置整个JSP页面的属性,如指定语言、导入包等;`include`指令用于在多个页面间共享内容;`taglib`指令引入自定义标签库。 ```jsp ; charset=UTF-8" pageEncoding="UTF-8"%> ...
JSTL是一套标准的标签库,包含核心、SQL、XML、JDBC等标签,可以替代脚本片段,使JSP页面更符合MVC模式。 7. **JSP 2.0及更高版本的特性**: - `page指令`中的`isThreadSafe`属性,默认为true,表示JSP页面是线程...
在IT行业中,Web开发是至关重要的领域,而`JSP+Servlet+JavaBean`模式是构建动态网站的经典组合。这个模式充分利用了MVC(模型-视图-控制器)设计模式,使得开发过程更加清晰和模块化。下面我们将深入探讨这个模式...
**JSP页面详解** JavaServer Pages(JSP)是一种基于Java技术的动态网页开发标准,由Sun Microsystems(现已被Oracle公司收购)在1999年推出,旨在简化Web应用程序的开发。JSP允许开发者将静态HTML内容和动态Java...
MVC模式(Model-View-Controller)是Web开发中常用的设计模式,其中模型处理数据,视图负责显示,控制器接收用户请求并协调模型和视图。 项目结构中的`.classpath`、`.mymetadata`、`.project`和`.myeclipse`文件是...
2. **视图(View)**:JSP页面扮演视图的角色,显示数据。通过EL(Expression Language)和JSTL(JavaServer Pages Standard Tag Library)标签,可以从模型中获取数据并展示在页面上。 3. **控制器(Controller)*...
2. **Servlet**:在JSP公交车查询系统中,JSP页面通常会转换成Servlet来执行。Servlet是Java Web应用中的服务器端组件,负责处理HTTP请求并生成响应。当用户发起请求时,JSP会被转换为Servlet实例,处理请求后返回...
本篇文章将深入探讨如何在JSP页面中利用JSTL来读取Service层传递过来的数据。 首先,我们需要理解JSP和JSTL的基本概念。JSP是一种服务器端的技术,它允许开发者在HTML中嵌入Java代码,以生成动态网页内容。然而,...
7. JSP页面接收到结果后,更新显示在显示屏上的值。 **文件名称列表分析**: 虽然未提供完整的文件列表,但可以推测"calcu"可能代表"calculator"的缩写。在实际的项目中,我们可能会有以下文件: - `calculation....
总结来说,"struts+mysql+jsp 分页"这个主题涉及到Struts框架中Action类的设计、MySQL数据库的分页查询以及JSP页面的动态渲染。通过合理的代码组织和利用MVC模式,可以实现高效、灵活的分页功能。在实际开发中,...
开发者需要在JSP中定义处理这些请求的逻辑,例如使用`<form>`标签和`action`属性来指定处理请求的JSP页面。 7. **响应处理**:服务器处理完请求后,会返回结果给客户端。这可能涉及到动态生成HTML内容,或者通过...
JSP页面在服务器上被编译成Servlet,然后执行。 2. **Servlet技术**: Servlet是Java中的一个接口,用于处理HTTP请求。在本项目中,Servlet用于接收用户请求,执行业务逻辑,并返回响应。Servlet与JSP配合,可以...
通过使用`<%= %>`表达式或者`<jsp:expression>`标签,开发者可以轻松地在页面上显示数据库查询结果或其他动态信息。 2. **表单处理**:JSP可以处理用户提交的表单数据。通过`<form>`标签和动作方法(如GET或POST)...
在`model2_demo`压缩包中,应该包含了一个完整的MyEclipse项目,包括Java源代码、JSP页面、配置文件等,可以作为学习和实践Model2模式的参考。 总的来说,Model2模式在JSP中的应用使得Web应用的结构更加清晰,降低...
EL是一种轻量级的脚本语言,用于在JSP页面中读取和设置JavaBean或其他作用域内的对象属性。例如`${bean.property}`。 四、JSTL(JSP Standard Tag Library) JSTL是一组标准的标签库,提供了许多实用的功能,如条件...
queryAll.jsp是顺序查询的JSP页面,使用JSTL的forEach标签遍历JavaBean的数据,显示学生信息。 知识点11:模糊查询 searchByName.jsp是模糊查询的JSP页面,提供了一个表单,用于输入学生姓名,然后提交到Service...