时间:2021-05-26
本文实例讲述了jsp页面常用的查询及显示方法。分享给大家供大家参考,具体如下:
背景:
1. 需要将数据库查询结果在JSP中以列表方式显示
2. 在一个良好的J2EE模式中数据库查询一般用DAO实现(Data Access Object), JSP仅用于显示数据
方法一:
建一个类,将查询出的结果封装到该类中,然后将该类对象添加到List中。(这个也是我最开始时用的方法,不通用且太麻烦了)。
方法二:
在介绍方法二的时候,我们先来看看如何把ResultSet转化为List吧,代码如下:
private static List resultSetToList(ResultSet rs) throws SQLException { List list = new ArrayList(); ResultSetMetaData md = rs.getMetaData(); int columnCount = md.getColumnCount(); while (rs.next()) { Map rowData = new HashMap(); for (int i = 1; i <= columnCount; i++) { rowData.put(md.getColumnName(i), rs.getObject(i)); } list.add(rowData); } return list;}遍历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();希望本文所述对大家jsp程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例总结了JSP清除页面缓存常用方法。分享给大家供大家参考,具体如下:一、清除页面缓存在jsp页里在html页里:二、清除cookie三、清除session
ajax提交数据到后台jsp页面及页面跳转问题我logincheck.jsp页面取传参数代码:Stringuser=request.getParameter("
JavaWeb项目中,解决中文乱码方法总结如下第一种情况:调用jsp页面中文显示乱码问题描述:通过浏览器调用jsp页面,在浏览器中显示的中文内容出现乱码。解决方
在早期开发的时候,我们完成的都是静态页面也就是html页面,随着时间轴的发展,慢慢的引入了jsp页面,当在后端服务查询到数据之后可以转发到jsp页面,可以轻松的
1.客户端网页代码复制代码代码如下:/info.jspinfo.jsp为显示信息页面复制代码代码如下:info.jsp是jsp页面,对于与安卓客户端交互的jsp