c3p0, dbcp 开源的连接池开源连接使用

本文介绍使用C3P0实现数据库连接池的方法。通过示例代码展示如何配置和初始化连接池,包括设置最大最小连接数等参数,并提供获取连接的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自己要实现一个连接池太复杂了!要考虑的东西太多,比如:连接对象的 close 方法处理、物理连接中断时处理、
数据库连接池耗尽了之后如何处理等等诸如此类的问题。

建议使用 c3p0, dbcp 等等这些开源的连接池。

下面这个是 c3p0 的,使用 ConnectionFactory.getConnection() 获得连接之后其他与 JDBC 一样使用。

Java code
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ -->import java.beans.PropertyVetoException; import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.SQLException; import org.apache.log4j.Logger; import com.bao.config.Config; import com.mchange.v2.c3p0.ComboPooledDataSource; public class ConnectionFactory { private final static Logger LOG = Logger.getLogger(ConnectionManager.class); private static ComboPooledDataSource ds = new ComboPooledDataSource(); private ConnectionFactory() { } static { try { if(LOG.isDebugEnabled()) { LOG.debug("正在初始化数据连接池"); } Config config = Config.getInstance(); // c3p0 的 DataSource 设置,其他的参数还有很多,参考 c3p0 文档 ds.setDriverClass(config.getJdbcDriver()); // JDBC 驱动 ds.setJdbcUrl(config.getJdbcUrl()); // JDBC URL ds.setUser(config.getDatabaseUsername()); // 数据库连接用户名 ds.setPassword(config.getDatabasePassword()); // 数据库连接用户名的密码 ds.setMaxPoolSize(config.getDatabasePoolMaxSize()); // 最大连接数 ds.setMinPoolSize(config.getDatabasePoolMinSize()); // 最小连接数 if(LOG.isDebugEnabled()) { LOG.debug("数据连接池初始化完成" + ", 最大可用连接数:" +ds.getMaxPoolSize() + ", 最小连接数:" + ds.getMinPoolSize()); } } catch (PropertyVetoException e) { LOG.error("连接池初始化失败,原因:" + e.getMessage()); e.printStackTrace(); } } public static Connection getConnection() throws SQLException { return ds.getConnection(); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值