TB源码分析:ConnectionManager

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

package com.terac.board;

import org.apache.commons.dbcp.ConnectionFactory;

import org.apache.commons.dbcp.DriverManagerConnectionFactory;

import org.apache.commons.dbcp.PoolableConnectionFactory;

import org.apache.commons.dbcp.PoolingDataSource;

import org.apache.commons.pool.ObjectPool;

import org.apache.commons.pool.impl.GenericObjectPool;

import javax.sql.DataSource;

import java.sql.SQLException;

public class ConnectionManager {

private final static ConnectionManager instance = new ConnectionManager();

private DataSource ds;

public static ConnectionManager getInstance() {

return instance;

}

private ConnectionManager() {

try {

//setupDriver();

this.ds = setupDataSource();

} catch (Exception e) {

//

}

}

public static DataSource setupDataSource() {

try {

Class.forName(Config.getInstance().getDatabaseDriver());

} catch (ClassNotFoundException e) {

//

}

ObjectPool connectionPool = new GenericObjectPool();

ConnectionFactory connectionFactory = new DriverManagerConnectionFactory(

Config.getInstance().getDatabaseUrl()

, Config.getInstance().getDatabaseUser()

, Config.getInstance().getDatabasePassword());

PoolableConnectionFactory poolableConnectionFactory = new PoolableConnectionFactory(connectionFactory, connectionPool, null, null, false, true);

PoolingDataSource dataSource = new PoolingDataSource(connectionPool);

return dataSource;

}

public DataSource getDataSource() throws SQLException {

return ds;

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航