public class JdbcUtils {
private static DataSource dataSource;
static {
dataSource = new ComboPooledDataSource();
}
public static DataSource getDataSource() {
return dataSource;
}
public static QueryRunner queryRunner() {
return new QueryRunner(dataSource);
}
}
请问一下,就是这上面这一段代码为什么能够创建连接池,并且能够顺利连接上数据库呢?这一段时间,自己写小项目,见得比较多,但是其中的原理不明白,所以想请问一下。拜谢!
你可以这样理解:相当于是下列代码,只不过使用properties文件要注意key值得前缀必须是c3p0;如 c3p0.driverClass=com.mysql.jdbc.Driver,可以看看源码
内部是自己读入properties文件得到数据库相关信息的
private static ComboPooledDataSource cpds = new ComboPooledDataSource();
static{
try {
cpds.setDriverClass("com.mysql.jdbc.Driver");
cpds.setJdbcUrl("jdbc:mysql://localhost:3306/createtable");
cpds.setUser("root");
cpds.setPassword("admin");
cpds.setInitialPoolSize(5);
} catch (Exception e) {
e.printStackTrace();
}
}
希望对你有帮助!