zoukankan      html  css  js  c++  java
  • 【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>
    

    给出完整的文件图片:

    named-config

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

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

    运行结果:

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

  • 相关阅读:
    Java Web学习总结(16)——JSP的九个内置对象
    Java Web学习总结(15)——JSP指令
    【我的物联网成长记11】8招带你玩转规则引擎
    云图说|高效管理华为云SAP的“秘密武器”
    Python 中更优雅的日志记录方案
    有了它,Python编码再也不为字符集问题而发愁了!
    【鲲鹏来了】手把手教你创造一个属于自己的鲲鹏开发者环境
    解密昇腾AI处理器--DaVinci架构(计算单元)
    使用Keil5构建GD32450i-EVAL工程
    云图说|SAP技术画册“一点通”
  • 原文地址:https://www.cnblogs.com/lihanxiang/p/8464268.html
Copyright © 2011-2022 走看看