分享
 
 
 

写了个连接池的类,和大家一起探讨

王朝java/jsp·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

写了个连接池的类,和大家一起探讨,欢迎交流 dalong_aa@163.com

package com.dalong.connectionpool;

import java.util.HashMap;

import java.util.Vector;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.*;

/**

* <p>Title: </p>

* <p>Description: test</p>

* <p>Copyright: Copyright (c) 2003</p>

* <p>Company: home</p>

* @author dalong

* @version 1.0

*/

public class ConnectionPool {

//连接池的管理器,首先初始化,仅仅有一个对象,管理连接池

private static HashMap connectionPoolManager=new HashMap();

//没有用过的连接池,用vector实现同步

private static Vector noUseConnectionPool;

//没有用过的连接池

private static HashMap nowUseConnectionPool;

private static String dbDriver="odbc:jdbc:OdbcJdbcDriver";

private static String dbUrl="dalong@XX";

private static String userName="dalong";

private static String userPassword="dalong";

//默认为100个连接池

private static int MAX_POOL=100;

//singleTon 设计模式

private ConnectionPool(String driver,String url,String name,String password,int max)

throws ClassNotFoundException {

Class.forName(driver);

dbUrl=url;

userName=name;

userPassword=password;

MAX_POOL=max;

}

public static ConnectionPool getConnManagerInstance(String poolName)

throws ClassNotFoundException{

ConnectionPool tempPool=(ConnectionPool)connectionPoolManager.get(poolName);

if(tempPool==null){

tempPool=new ConnectionPool(dbDriver,dbUrl,userName,userPassword,MAX_POOL);

connectionPoolManager.put(poolName,tempPool);

return tempPool;

}else

return tempPool;

}

//通过连接池获得真正的链接

public static Connection getConnection() throws java.sql.SQLException{

Connection conn=null;

synchronized(noUseConnectionPool){

if(noUseConnectionPool.size()>0){

conn=(Connection)noUseConnectionPool.firstElement();

noUseConnectionPool.remove(conn);

return conn;

}

}

//如果数据库连接池没有链接了,自己创建一个

if(conn==null){

conn=createConnection(dbDriver,dbUrl,userName,userPassword);

}else if(conn.isClosed()){

nowUseConnectionPool.remove(conn);

conn=createConnection(dbDriver,dbUrl,userName,userPassword);

}

conn.setAutoCommit(false);

nowUseConnectionPool.put(conn,conn);

return conn;

}

//如果连接池没有链接了,就需要产生一个链接

private static Connection createConnection(String driver,String url,String user,String password)

throws java.sql.SQLException{

Connection conn=DriverManager.getConnection(url,user,password);

return conn;

}

public static void releaseConnection(Connection conn,boolean isCommit)

throws java.sql.SQLException{

if(isCommit)

conn.commit();

else

conn.rollback();

nowUseConnectionPool.remove(conn);

if(noUseConnectionPool.size() + nowUseConnectionPool.size()<MAX_POOL){

synchronized(noUseConnectionPool){

noUseConnectionPool.add(conn);

}

}else{

conn.close();

}

}

public static void main(String[] args) {

//测试模拟10个客户

for (int i = 0; i < 10; i++) {

try {

//xxxx 一般为属性文件读取

ConnectionPool pool = ConnectionPool.getConnManagerInstance("xxxx");

Connection conn = pool.getConnection();

}catch (SQLException ex1) {

//处理异常

}

catch (ClassNotFoundException ex) {

//处理异常

}

}

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有