优雅天平

享受喧嚣 安于平静
posts(18) comments(167) trackbacks(0)
  • BlogJava
  • 联系
  • RSS 2.0 Feed 聚合
  • 管理

常用链接

  • 我的随笔
  • 我的评论
  • 我的参与
  • 最新评论

留言簿

  • 给我留言
  • 查看公开留言
  • 查看私人留言

随笔档案(18)

  • 2006年4月 (1)
  • 2006年3月 (1)
  • 2005年12月 (3)
  • 2005年10月 (2)
  • 2005年9月 (1)
  • 2005年7月 (2)
  • 2005年6月 (3)
  • 2005年3月 (2)
  • 2005年2月 (3)

文章分类(62)

  •  eclipse(2)
  •  Guitar(11)
  •  J2EE相关(5)
  •  JAVA基础(7)
  •  Solaris相关(1)
  •  WAP相关(1)
  •  web services(12)
  •  web页面基础(4)
  •  开源相关(16)
  •  数据库/仓库(2)
  •  模式相关(1)

文章档案(61)

  • 2006年2月 (1)
  • 2006年1月 (3)
  • 2005年12月 (32)
  • 2005年11月 (8)
  • 2005年9月 (6)
  • 2005年8月 (1)
  • 2005年6月 (6)
  • 2005年5月 (1)
  • 2005年3月 (1)
  • 2005年2月 (2)

相册

  • 大事记
  • 我的照片

blog

  • 小江西
  • 铁手剑谱的blog-strust
  • 陶永胜书法艺术中心

站点搜藏

  • Matrix-与Java共舞
  • OpenSource
  • 中国java开发网

搜索

  •  

积分与排名

  • 积分 - 142692
  • 排名 - 437

最新评论

  • 1. re: JFreeChart完全攻略示例各种方法和属性[未登录]
  • sdfg
  • --111
  • 2. re: JFreeChart完全攻略示例各种方法和属性
  • 分数线烦不烦很舒服发个号发给合适的给他发所提供合适的土壤规范不能是纳税人他呢过生日能接受洒脱人呢是vae回复身体然后呢托管人粉红丝带让他反感 受托人复活币善待他人回事
  • --倒萨倒
  • 3. re: Jcreator注册码[未登录]
  • 有谁有jcreator 5.0 pro的注册码呀?跪求
  • --liu
  • 4. re: 开启log4j的记录源代码行号的配置,会对系统性能产生影响!
  • 怎么说呢?理解的有点片面。。。jdk1.4之前的话的确对性能影响比较大,自从1.4开始引入了StackTraceElement之后,对性能影响不是那么大。。。
  • --黄大仙
  • 5. re: 请问MYECLIPSE在哪里输入注册码呀?[未登录]
  • 对我这个初学者有帮助,嘿嘿。
  • --Flyer

阅读排行榜

  • 1. Jcreator注册码(22639)
  • 2. java日期相减问题(20246)
  • 3. Myeclipse注册码(13945)
  • 4. jbuilder 2006 破解文件(13716)
  • 5. 修改 Oracle9i 8080端口问题(2888)

评论排行榜

  • 1. jbuilder 2006 破解文件(58)
  • 2. Jcreator注册码(50)
  • 3. Myeclipse注册码(18)
  • 4. JBuilder2005光标问题更好的解决方法(6)
  • 5. B/S结构程序等待查询结果超时问题(5)

View Post

JSP中早就有了类似.Net DataSet那样的离线数据访问了,抛弃ResultSet,拥抱Result吧!

微软的.NET平台上面的数据访问有一个特点,就是数据查询的结果,可以放在内存中,以XML格式进行描述,不需要一直与数据库保持在线连接,用DataSet + Data Adapter来实现!

而在JDBC中,我们通常使用javax.sql.ResultSet类来存放放回的数据,它的流程和生命周期如下:

使用ResultSet来返回数据库查询结果
Client --> Connection --> Statement --> JDBC Driver --+
  Database
Client <-- Parsing <-- ResultSet <-- JDBC Driver --+
               
  Connection lifecycle
   
   
 
  ResultSet lifecycle  
 

我们可以看到,这样会长期占用数据库连接的资源,是一个有点不爽的问题...

其实,在JSTL中提供了另外一种机制,让我们在返回查询结果到表示层的时候,可以做到离线使用!它就是javax.servlet.jsp.jstl.sql.Result类!

 1 <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
2 <%@page contentType="text/html; charset=UTF-8"%>
3 <%@page import="java.sql.Connection"%>
4 <%@page import="java.sql.DriverManager"%>
5 <%@page import="java.sql.ResultSet"%>
6 <%@page import="java.sql.SQLException"%>
7 <%@page import="java.sql.Statement"%>
8 <%@page import="javax.servlet.jsp.jstl.sql.Result"%>
9 <%@page import="javax.servlet.jsp.jstl.sql.ResultSupport"%>
10 <%
11 // 暂且把这个下面的内容看作多层架构中的DAO好了,我偷懒了!
12 Connection conn = null;
13 Statement stmt = null;
14 ResultSet rs = null;
15 String strDbUrl
16 = "jdbc:mysql://localhost/tutorial?user=tutorial&password=tutpwd";
17 try {
18 //开始与数据库作查询
19 Class.forName("com.mysql.jdbc.Driver").newInstance();
20 conn = DriverManager.getConnection(strDbUrl);
21 stmt = conn.createStatement();
22 String strSql = "SELECT * FROM R_TUT_USERS";
23 rs = stmt.executeQuery(strSql);
24 //把ResultSet转化成Result
25 Result userData = ResultSupport.toResult(rs);
26 //当我们把结果放到某个Model bean后,就可以关闭数据库连接了.
27 //为了简化,我们暂且把pageContext看作Model Bean好了!
28 pageContext.setAttribute("userData", userData);
29 }
30 catch (Exception ex) {
31 // handle any errors
32 System.out.println("SQLException: " + ex.getMessage());
33 }
34 finally {
35 try {
36 if (rs != null) {
37 rs.close();
38 }
39 if (stmt != null) {
40 stmt.close();
41 }
42 if (conn != null) {
43 conn.close();
44 }
45 }
46 catch (SQLException ex) {
47 System.out.println("SQL Exception: " + ex.getMessage());
48 }
49 }
50 //DAO的逻辑结束
51 %>
52 <html>
53 <head>
54 <title>test</title>
55 </head>
56 <body>
57 <!--// 下面当作是表示层吧 //-->
58 <c:forEach items="${userData.rows}" var="user">
59 <c:out value='${user.name}'/>
60 </c:forEach>
61 </body>
62 </html>

posted on 2005-12-09 11:08 Victor 阅读(599) 评论(0)  编辑  收藏 所属分类: JAVA基础

新用户注册  刷新评论列表  

只有注册用户登录后才能发表评论。


网站导航:
博客园   IT新闻   Chat2DB   C++博客   博问   管理
相关文章:
  • Java初学者容易混淆的几个问题
  • Java读取XML文件的工具类
  • JSP中早就有了类似.Net DataSet那样的离线数据访问了,抛弃ResultSet,拥抱Result吧!
  • java中文问题详解(转)
  • 最安全的加密算法 (摘自温少的blog)
  • JSP编程进度条设计实例(转)
  • Java 编程技术中汉字问题的分析及解决(转)
 
 
Powered by:
BlogJava
Copyright © Victor