c3p0 mysql demo_数据库连接池 c3p0 demo 代码和分析

importjava.sql.Connection;importjava.sql.SQLException;importjava.beans.PropertyVetoException;importcom.mchange.v2.c3p0.ComboPooledDataSource;public classDafa {private staticDBPool dbPool;privateComboPooledDataSource dataSource;static{

dbPool= newDBPool();

}publicDafa() {try{

dataSource= newComboPooledDataSource();

dataSource.setUser("id ");

dataSource.setPassword("pw ");

dataSource.setJdbcUrl("jdbc:mysql://127.0.0.1:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=GB2312 ");

dataSource.setDriverClass("com.mysql.jdbc.Driver ");

dataSource.setInitialPoolSize(2);

dataSource.setMinPoolSize(1);

dataSource.setMaxPoolSize(10);

dataSource.setMaxStatements(50);

dataSource.setMaxIdleTime(60);

}catch(PropertyVetoException e) {throw newRuntimeException(e);

}

}public final staticDBPool getInstance() {returndbPool;

}public finalConnection getConnection() {try{returndataSource.getConnection();

}catch(SQLException e) {throw new RuntimeException("无法从数据源获取连接 ", e);

}

}public static void main(String[] args) throwsSQLException {

Connection con= null;try{

con=DBPool.getInstance().getConnection();

}catch(Exception e) {

}finally{if (con != null)

con.close();

}

}

}

使用连接池的时候并不是在代码中不用获取/释放数据库连接,而是在代码中向连接池申请/释放连接,对于代码而言,可以把连接池看成数据库。

换句话说,连接池就是数据库的代理,之所以要使用这个代理是因为直接向数据库申请/释放连接是要降低性能的:如果每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,那么频繁发生这种数据库操作时,系统的性能必然会急剧下降。

连接池的作用是自己维护数据库连接,数据库连接池的主要操作如下:

(1)建立数据库连接池对象(服务器启动)。

(2)按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数)。

(3)对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的数据库连接。

(4)存取数据库。

(5)关闭数据库,释放所有数据库连接(此时的关闭数据库连接,并非真正关闭,而是将其放入空闲队列中。如实际空闲连接数大于初始空闲连接数则释放连接)。

(6)释放数据库连接池对象(服务器停止、维护期间,释放数据库连接池对象,并释放所有连接)。

转自:http://hi.baidu.com/zjq588/item/df2aa4c899024711505058ff

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值