构建一个高可扩展性javabean和jsp连接数据库操作
1. 我们先在Tomcat 中创建一个DataSource- jdbc/Panabia,然后再创建一个java“基类”,这个类封装了数据库连接和连接的释放。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85 |
package
Panabia.db; import javax.sql.DataSource; import javax.naming.*; import java.sql.*; public class SQLFactory { private
static DataSource ds = null ; private
static Object Lock = new
Object(); // 生成DataSource** public
static DataSource gainDataSource() { try { if (ds== null ) { synchronized (Lock) { if (ds== null ) { Context ctx= new
InitialContext(); ds=(DataSource)ctx.lookup(\"java:comp/env/jdbc/Panabia\"); } } } } catch (NamingException e){ e.printStackTrace(); } return
ds; } // 生成SQL连接** public
static synchronized Connection gainConnection() { Connection con = null ; try { if (ds == null ) { gainDataSource(); } con = ds.getConnection(); } catch
(SQLException e){ e.printStackTrace(); } return
con; } // 释放SQL连接** public
static void releaseConnection(ResultSet rs, PreparedStatement ps, Statement sql, Connection con) { try { if
(rs != null ) rs.close(); } catch
(SQLException e) { e.printStackTrace(); } try { if
(ps != null ) ps.close(); } catch
(SQLException e) { e.printStackTrace(); } try { if
(sql != null ) sql.close(); } catch (SQLException e) { e.printStackTrace(); } try
{ if
(con != null
&& !con.isClosed()) con.close(); } catch
(SQLException e) { e.printStackTrace(); } } } |
大家都应该注意到了,这个类的所有的方法全部是static的,之所以这样,主要是为了方便其它“扩展类”的调用,当然,还有其它好处--- :)
2. 然后,这个类就封装完毕了,现在我们就可以针对不同的应用要求单独写javaBean了,比如一个简单的:在JSP中列出verify表中的所有用户名与密码列表。
该怎么做?--使用SQLFactory生成Connection,再生成Statement,再生成ResultSet--然后枚举吗?好象不错,哦,等等......这样做你难道没有一种“非常亲切”的感觉吗?---对了,ASP,PHP中就是如此-Faint~我们怎么又回到“原始社会”了....
有没有更好的方式?答案是肯定的,JAVA的能力是“通天”的强大,只要你能想得到,仔细看看它的API Document,就不难找出解决办法。
答案出来了:
我们在查询类中返回Iterator到JSP枚举,而不是ResultSet。
好了,我们的UserQuery类就产生了:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35 |
package
Panabia.operate; import Panabia.db.SQLFactory; import java.util.*; import java.sql.*; public class UserQuery { private
ArrayList list = null ; private
Connection con = null ; private
Statement sql = null ; private
ResultSet rs = null ; public
Iterator getResult() { try { con=SQLFactory.gainConnection(); sql=con.createStatement(); rs=sql.executeQuery(\"select * from verify\"); //verify表只有两个字段:username,password; list= new
ArrayList(); while (rs.next()) { list.add(rs.getString( 1 )); list.add(rs.getString( 2 )); } } catch (SQLException e){ e.printStackTrace(); } finally { SQLFactory.releaseConnection(rs, null ,sql,con); } return
list.iterator(); } } |
3. 在jsp页面进行查询
1
2
3
4
5 |
Iterator it=UserQuery.getResult(); while (it.hasNext()) { out.print((String)it.next()); }<br><br> //尚不完善的地方:虽然情况好了一些,但当使用ArrayList取出体积很大的数据时,会相当耗费系统资源[系统会在内存单独开一块空间存放结果]---相关的优化方法是有的,我在这里就不作陈述了,大家可以参考一下其它的相关资料。 |
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。