构建一个高可扩展性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取出体积很大的数据时,会相当耗费系统资源[系统会在内存单独开一块空间存放结果]---相关的优化方法是有的,我在这里就不作陈述了,大家可以参考一下其它的相关资料。
本文转自二郎三郎博客园博客,原文链接:http://www.cnblogs.com/haore147/p/3618220.html,如需转载请自行联系原作者
相关文章
|
4天前
|
关系型数据库 MySQL API
新手教程:数据库操作(使用PDO或MySQLi扩展)
本文为新手介绍如何使用PDO和MySQLi扩展连接与操作MySQL数据库。PDO更现代灵活,支持多种数据库,适合大多数应用;MySQLi提供面向过程和面向对象两种API,适合直接控制数据库操作。教程涵盖安装配置、创建连接、执行查询(查询、插入、更新、删除)及错误处理等内容。希望这篇教程能帮助你快速上手PHP中的数据库操作!
50 32
|
16天前
|
人工智能 容灾 关系型数据库
【AI应用启航workshop】构建高可用数据库、拥抱AI智能问数
12月25日(周三)14:00-16:30参与线上闭门会,阿里云诚邀您一同开启AI应用实践之旅!
|
2月前
|
数据库 C# 开发者
ADO.NET连接到南大通用GBase 8s数据库
ADO.NET连接到南大通用GBase 8s数据库
|
2月前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
2月前
|
存储 SQL API
探索后端开发:构建高效API与数据库交互
【10月更文挑战第36天】在数字化时代,后端开发是连接用户界面和数据存储的桥梁。本文深入探讨如何设计高效的API以及如何实现API与数据库之间的无缝交互,确保数据的一致性和高性能。我们将从基础概念出发,逐步深入到实战技巧,为读者提供一个清晰的后端开发路线图。
|
2月前
|
缓存 NoSQL 数据库
运用云数据库 Tair 构建缓存为应用提速,完成任务得苹果音响、充电套装等好礼!
本活动将带大家了解云数据库 Tair(兼容 Redis),通过体验构建缓存以提速应用,完成任务,即可领取罗马仕安卓充电套装,限量1000个,先到先得。邀请好友共同参与活动,还可赢取苹果 HomePod mini、小米蓝牙耳机等精美好礼!
|
2月前
|
JSON JavaScript 关系型数据库
node.js连接GBase 8a 数据库 并进行查询代码示例
node.js连接GBase 8a 数据库 并进行查询代码示例
|
2月前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
51 1
|
2月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
2月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)
本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。