1.首先是配置文件,配置文件放在src下面,命名必须为c3p0-config.xml,否则获取数据源时候jar找不到配置文件,就需要手动指定配置文件地址。
<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
<default-config>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/testdatabase</property>
<property name="user">root</property>
<property name="password">root</property>
<!-- 连接池中保留的最小连接数 -->
<property name="minPoolSize">20</property>
<!-- 连接池中保留的最大连接数 -->
<property name="maxPoolSize">100</property>
<!-- 初始化时的连接数量,取值应在minPoolSize与maxPoolSize之间 -->
<property name="initialPoolSize">20</property>
<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数 -->
<property name="acquireIncrement">3</property>
<!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
<property name="acquireRetryAttempts">30</property>
<!-- JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements
属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。
如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->
<property name="maxStatements">100</property>
<!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->
<property name="maxStatementsPerConnection">0</property>
<!--每60秒检查所有连接池中的空闲连接-->
<property name="idleConnectionTestPeriod">60</property>
<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃 -->
<property name="maxIdleTime">60</property>
</default-config>
</c3p0-config>
2.java文件,得到c3p0连接池的连接
package callProDemo;
import java.sql.Connection;
import java.sql.SQLException;
import com.mchange.v2.c3p0.ComboPooledDataSource;
/**
* @author Administrator
* @date 2015年12月4日 下午1:56:27
* @description 获取C3P0连接对象
*/
public class C3p0ConnectionProvider {
//数据源对象,从c3p0-config.xml中自动获取
private static ComboPooledDataSource dataSource;
//读取c3p0配置文件
static {
dataSource = new ComboPooledDataSource();
}
//获取连接池中的连接
public static Connection getConnection() throws SQLException {
return dataSource.getConnection();
}
//关闭连接池的连接连接
public static void closeConnection(Connection conn) throws SQLException{
if(conn != null){
conn.close();
}
}
}
C3p0ConnectionProvider.getConnection(); //getConnection