【JavaWeb】c3p0连接池与MySQL

正文之前

在之前的文章讲到了传统的JDBC连接MySQL的方式,但是这样的方式在进行多个连接时,就显得效率低下,明显不如连接池的效率,所以我们这次来讲解一下JDBC连接池之一:c3p0


正文

1. 准备工作
  • IntelliJ IDEA
  • c3p0-0.9.5.2(jar)
  • MySQL
2. 配置 c3p0-config.xml
default-config

在配置之前,需要先进行建立数据库的工作,本文还是采用上篇文章中的名为 customer 的数据库

然后在工程的 src 目录下新建一个名为 c3p0-config 的XML文件(文件名不能自定义)

然后开始配置:

        <!-- 数据库地址 -->
        <property name="jdbcUrl">jdbc:mysql://localhost:3306/customer</property>
        <!-- 数据库驱动 -->
        <property name="driverClass">com.mysql.jdbc.Driver</property>
        <!-- 用户名 -->
        <property name="user">root</property>
        <!-- 密码 -->
        <property name="password">3865933</property>

先写基本的数据库信息,然后我们再来写常用的连接池属性,若要查询全部属性,可阅读官网指南,属性也包含于中:

        <!-- 连接池初始化时创建的连接数 -->
        <property name="initialPoolSize">1</property>
        <!-- 连接池中的最小连接数 -->
        <property name="minPoolSize">1</property>
        <!-- 连接池中的最小连接数 -->
        <property name="maxPoolSize">2</property>
        <!-- 无空闲连接可用时,可一次性创建新连接的数量 -->
        <property name="acquireIncrement">1</property>
        <!-- 获取数据库连接失败后重复尝试的次数 -->
        <property name="acquireRetryAttempts">1</property>
        <!-- 两次连接的间隔时间,单位为毫秒 -->
        <property name = "acquireRetryDelay">1000</property>

给出完整的文件图片:

1240

named-config

可以添加 named-config 来增加数据库配置,内容与default-config一致,我连接了另一个数据库 product :

1240

3. 写个demo

先搞定数据源:

    private static ComboPooledDataSource dataSource1 = new ComboPooledDataSource("test");
    private static ComboPooledDataSource dataSource2 = new ComboPooledDataSource();

根据数据源,进行连接

    private static void getConnection(){
        try{
            Connection connection = dataSource1.getConnection();
            System.out.println("连接数据库 product 成功!");
            connection.close();
            System.out.println("数据库连接已关闭!");
        }catch(Exception e){
            System.out.println("连接数据库失败!");
        }
        try{
            Connection connection = dataSource2.getConnection();
            System.out.println("连接数据库 customer 成功!");
            connection.close();
            System.out.println("数据库连接已关闭!");
        }catch(Exception e){
            System.out.println("连接数据库失败!");
        }
    }
    public static void main(String[] args){
        getConnection();
    }

运行结果:

1240

如果需要有多个连接,使用连接池是不二之选,关于c3p0的讲解到此为止了,谢谢。

转载于:https://www.cnblogs.com/lihanxiang/p/8464268.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值