博客首页 注册 建议与交流 排行榜 加入友情链接
推荐 投诉 搜索: 帮助

枫笛雨声

踏实办事,真诚待人!
  michaelzxf.cublog.cn

关于作者
职业:学生
位置:大连
个性介绍:Java Programming
|| << >> ||
我的分类


JDBC连接池
在连接数量及连接时间(是否超时)上面没有很好的处理,望多指教!

package com.dlut.zxf.sql;

import java.util.*;
import java.sql.*;

public class ConnectionPool {
    private Hashtable<Connection, Boolean> connections = new Hashtable<Connection, Boolean>();
    private Properties props;
    
    public ConnectionPool(Properties pros, int initialConnections)
    throws SQLException, ClassNotFoundException {
        this.props = props;
        initializePool(props, initialConnections);
    }
    public ConnectionPool(String driverClassName, String dbURL,
            String user, String password, int initialConnections)
    throws SQLException, ClassNotFoundException {
        props = new Properties();
        props.put("connection.driver", driverClassName);
        props.put("connection.url", dbURL);
        props.put("user", user);
        props.put("password", password);
        initializePool(props, initialConnections);
    }
   
    /*
     * 得到一个新的连接
     */
    public Connection getConnection() throws SQLException {
        Connection conn = null;
        Enumeration<Connection> connEnum = connections.keys();
        synchronized(connections) {
            while(connEnum.hasMoreElements()) {
                conn = connEnum.nextElement();
                Boolean b = connections.get(conn);
                if (b.equals(Boolean.FALSE)) {
                    try {
                        conn.setAutoCommit(true);
                    } catch(SQLException e) {
                        e.printStackTrace();
                        connections.remove(conn);
                        conn = getNewConnection();
                    }
                    connections.put(conn, Boolean.TRUE);
                    //connections.put(conn, Boolean.FALSE); ?
                    return conn;
                }
            }
            conn = getNewConnection();
            connections.put(conn, Boolean.TRUE);
            return conn;
        }
    }
   
    public void returnConnection(Connection returned) {
        if (connections.containsKey(returned)) {
            connections.put(returned, Boolean.FALSE);
        }
    }
   
    private void initializePool(Properties props, int initialConnections)
    throws SQLException, ClassNotFoundException {
        Class.forName(props.getProperty("connection.driver"));
        for (int i=0; i<initialConnections; i++) {
            Connection conn = getNewConnection();
            connections.put(conn, Boolean.FALSE);
        }
    }
   
    private Connection getNewConnection() throws SQLException {
        return DriverManager.getConnection(props.getProperty("connection.url"), props);
    }
}


源代码下载
文件:ConnectionPool.rar
大小:0KB
下载:下载

发表于: 2008-03-15,修改于: 2008-03-15 12:18,已浏览294次,有评论0条 推荐 投诉


网友评论
 发表评论