liuzhihu2016
2016-06-23 13:01
采纳率: 100%
浏览 1.9k
已采纳

创建c3p0连接池的原理

 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);
    }

}

请问一下,就是这上面这一段代码为什么能够创建连接池,并且能够顺利连接上数据库呢?这一段时间,自己写小项目,见得比较多,但是其中的原理不明白,所以想请问一下。拜谢!

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • 有盐先生 2016-06-23 15:01
    已采纳

    你可以这样理解:相当于是下列代码,只不过使用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();
    }
    }

    希望对你有帮助!
    
    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题