mysql d3p0连接池_五、数据库连接池

作用

为了使得连接池为各个程序共用,而不是每个程序都申请一个连接池,可以定义一个工具类,使得有且仅提供一个连接池。

实现思路

在工具类的static块内创建数据库连接池对象即可,为使得类全局可用该对象,也同样定义个static属性以引用连接池对象,然后定义好getConnection()方法和close重载方法。最后提供一个返回工具类连接池的方法以供一些框架使用。

获取连接池对象

private static DataSource ds;

static {

Properties pro = new Properties();

try {

pro.load(JDBCUtils.class.getClassLoader().getResourceAsStream("DataSource/properties/durid.properties"));

ds = DruidDataSourceFactory.createDataSource(pro);

//c3p0直接new一个对象丢给ds

} catch (IOException e) {

e.printStackTrace();

} catch (Exception e) {

e.printStackTrace();

}

}

封装方法

public static void close(ResultSet rs, Statement stmt, Connection conn){

if (rs != null){

try {

rs.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if (stmt != null){

try {

stmt.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if (conn != null){

try {

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

public static void close(Statement stmt, Connection conn) {

close(null,stmt,conn);

}

public static DataSource getDataSource(){

return ds;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值