C3P0数据库连接池
C3P0是一个开源的JDBC数据库连接池,之前文章中提到过DBCP连接池,C3P0和DBCP连接池的区别是DBCP没有自动回收空闲连接的功能,而C3P0有自动回收空闲连接功能。接下来就是C3P0数据库连接池的使用步骤
所需jar包
c3p0-0.9.5.2.jar
mchange-commons-java-0.2.11.jar
mysql-connector-java-5.1.37-bin.jar
链接:https://pan.baidu.com/s/1QIN1UcGcNskBwl1h5p8ZGQ
提取码:gup9
开始
-
将上述jar包导入项目中
-
在config资源包下新建c3p0-config.xml配置文件
<?xml version="1.0" encoding="UTF-8"?> <c3p0-config> <default-config> <property name="initialPoolSize">10</property> <property name="maxIdleTime">30</property> <property name="maxPoolSize">100</property> <property name="minPoolSize">10</property> <property name="maxStatements">200</property> </default-config> <named-config name="mysql"> <property name="driverClass">com.mysql.jdbc.Driver</property> <property name="jdbcUrl">jdbc:mysql://localhost:3306/myservlet</property> <property name="user">root</property> <property name="password">root</property> <property name="initialPoolSize">10</property> <property name="maxIdleTime">30</property> <property name="maxPoolSize">100</property> <property name="minPoolSize">10</property> <property name="maxStatements">200</property> </named-config> </c3p0-config>
-
新建C3P0Utils.java工具类
public class C3p0Utils { private static ComboPooledDataSource dataSource = null; static{ //新建数据库连接池,注意这里的参数必须同c3p0-config.xml中的named-config标签中的name的值相同 dataSource = new ComboPooledDataSource("mysql"); } public static Connection getConnection(){ Connection conn = null; try { //获得连接 conn = dataSource.getConnection(); } catch (SQLException e) { e.printStackTrace(); } return conn; } public static DataSource getDataSource(){ return dataSource; }
-
测试获取的连接是否可用,使用JUnit4:右键点击工程名 -> Bulid Path -> Add Liblraries -> JUnit
@Test public void test(){ System.out.println(getConnection()); }
-
出现以下结果,说明连接可用