下午没事做,第一次尝试着写数据连接池。
想到了大概几点:1.使用单例模式;2.在构造方法中将数据源初始化;3.大概包括几个方法:init()、destroy()、getConnect()、release()
代码如下:
1.连接池类:
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class DBPool
{
2data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
3data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
4
* 用个集合来装连接
5
*/
6
private Vector<Connection> pool;
7data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
8
* 驱动名字
9
*/
10
private String driverClassName;
11data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
12
* url
13
*/
14
private String url;
15data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
16
* 用户名
17
*/
18
private String userName;
19data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
20
* 密码
21
*/
22
private String passWord;
23data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
24
* 连接池大小
25
*/
26
private int poolSize;
27data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
28data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
29
* 单例模式
30
*/
31
private static DBPool instance = null;
32data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
33data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
34
* 获取对象
35
*
36
* @return
37
*/
38data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static synchronized DBPool getInstance()
{
39data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (instance == null)
{
40
instance = new DBPool();
41
}
42
return instance;
43
}
44data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
45data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
46
* 构造方法+初始化
47
*/
48data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private DBPool()
{
49
// DBSourceBean,装driver,url,username,password和一些初始化方法
50
DBSourceBean dbSource = new DBSourceBean();
51data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
52
// 将从DBSourceBean获取的数据源对象的值赋值
53
this.driverClassName = dbSource.getDriverClassName();
54
this.url = dbSource.getUrl();
55
this.userName = dbSource.getUserName();
56
this.passWord = dbSource.getPassWord();
57
this.poolSize = dbSource.getPoolSize();
58data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
59
// 初始化
60
init();
61
}
62data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
63data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
64
* 初始化
65
*/
66data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private void init()
{
67
// 创建大小为连接池大小的Vector
68
pool = new Vector<Connection>(poolSize);
69data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
70
// 将连接装到Vector中去
71
addConnection();
72
}
73data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
74data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
75
* 制造连接池
76
*/
77data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private void addConnection()
{
78
Connection conn = null;
79data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
80data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < poolSize; i++)
{
81data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
82
// 用jakarta commons的db的组件简化
83
DbUtils.loadDriver(driverClassName);
84
// 获取连接
85
conn = DriverManager.getConnection(url, userName, passWord);
86
// 将连接加入到Vector中去
87
pool.add(conn);
88data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
89
}
90data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
91
e.printStackTrace();
92
}
93
}
94data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
95data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
96
* 外部获取连接使用的方法
97
*
98
* @return
99
*/
100data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public synchronized Connection getConnection()
{
101data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (pool.size() > 0)
{
102
Connection conn = pool.get(0);
103
pool.remove(conn);
104
return conn;
105data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
106
return null;
107
}
108
}
109data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
110data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
111
* 销毁连接池
112
*/
113data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public synchronized void destroy()
{
114data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
115data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (pool != null)
{
116data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < pool.size(); i++)
{
117
((Connection) pool.get(i)).close();
118
pool.remove(i);
119
}
120
}
121data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
122
e.printStackTrace();
123
}
124data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
125
}
126data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
127data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
128
* 释放一个连接
129
*
130
* @param conn
131
*/
132data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public synchronized void release(Connection conn)
{
133
pool.add(conn);
134
}
135
136
}
137
//set,get方法省略
2.数据源的bean类
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class DBSourceBean
{
2data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
3
* 驱动类名
4
*/
5
private String driverClassName;
6data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
7
* url
8
*/
9
private String url;
10data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
11
* 用户名
12
*/
13
private String userName;
14data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
15
* 密码
16
*/
17
private String passWord;
18data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
19
* 连接池大小
20
*/
21
private int poolSize;
22data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
23data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
24
* 读取配置文件
25
*/
26data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private void readConfig()
{
27
FileInputStream fis = null;
28
Properties props = null;
29
String path = "";
30data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
31
path = Thread.currentThread().getContextClassLoader().getResource("").toString();
32
path += "\\dataSource.properties";
33
path = path.substring("file:\\".length());
34
fis = new FileInputStream(path);
35
props = new Properties();
36
props.load(fis);
37
this.driverClassName = props.getProperty("driverClassName");
38
this.url = props.getProperty("url");
39
this.userName = props.getProperty("userName");
40
this.passWord = props.getProperty("passWord");
41
this.poolSize = Integer.parseInt(StringUtil.nvm(props.getProperty("poolSize"), "1"));
42data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (FileNotFoundException e)
{
43
e.printStackTrace();
44data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (IOException e)
{
45
e.printStackTrace();
46
}
47
}
48
}
49
//set,get方法省略
3.属性文件dataSource.properties
driverClassName=oracle.jdbc.driver.OracleDriver
userName=scott
passWord=tiger
url=jdbc:oracle:thin:@localhost:1521:sure
poolSize=10
4.测试类
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class TestDB
{
2data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
3data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static void main(String[] args)
{
4
5
DBPool db = null;
6
Connection conn = null;
7
String sql = "select empno,ename from emp";
8data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
9data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
10
long first = System.currentTimeMillis();
11
System.out.println("------111111开始计时-------");
12
// for (int j = 0; j < 10; j++) {
13
// QueryRunner qr = new QueryRunner();
14
// String sql = "select empno,ename from emp";
15
// List results = (List) qr.query(conn, sql, new MapListHandler());
16
//
17
//
18
// for (int i = 0; i < results.size(); i++) {
19
// Map map = (Map) results.get(i);
20
// }
21
// }
22data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < 100; i++)
{
23
db = DBPool.getInstance();
24
conn = db.getConnection();
25
Statement stmt = conn.createStatement();
26
ResultSet rs = stmt.executeQuery(sql);
27data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (rs.next())
{
28
}
29
rs.close();
30
stmt.close();
31
db.release(conn);
32
}
33
long last = System.currentTimeMillis();
34
System.out.println("------111111共耗时" + (last - first) + "-------");
35
36data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
37data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
38
* 测试非连接池的
39
*/
40
String driverName = "oracle.jdbc.driver.OracleDriver";
41
String url = "jdbc:oracle:thin:@localhost:sure";
42
String userName = "scott";
43
String passWord = "tiger";
44
first = System.currentTimeMillis();
45
System.out.println("------222222开始计时-------");
46data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < 100; i++)
{
47
Class.forName(driverName);
48
Connection conn1 = DriverManager.getConnection(url, userName,
49
passWord);
50
Statement stmt1 = conn1.createStatement();
51
ResultSet rs1 = stmt1.executeQuery(sql);
52data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (rs1.next())
{
53
}
54
rs1.close();
55
conn1.close();
56
stmt1.close();
57
}
58data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
59
last = System.currentTimeMillis();
60
System.out.println("------2222222共耗时" + (last - first) + "-------");
61data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
62data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (ClassNotFoundException e)
{
63
e.printStackTrace();
64data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (SQLException e)
{
65
e.printStackTrace();
66
}
67
}
68
}
69data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
5.总结:功能还很不完善,连接池和管理连接池可以分开写,还有一些其他的欠考虑,数据源可以用xml来存放,等等。。想好了再改
posted on 2008-07-31 22:16
xrzp 阅读(231)
评论(0) 编辑 收藏 所属分类:
JAVA