数据库连接池

1.数据库连接池

1.1 概念

  数据库连接池其实就是一个存放数据库连接的容器。当系统初始化后,容器被创建,然后申请一些连接对象放入容器内。当用户来访问数据库时,从容器中获取连接对象;当用户访问完之后,会将连接对象归还给容器。

1.2 好处

(1)节约资源
(2)访问高效,不需要不断的申请数据库连接和释放。

1.3 实现

(1)标准接口:DataSource(javax.sql包下)

  • 接口中的方法:
    ① 获取连接:getConnection();
    ② 归还连接:Connection.close();如果连接对象Connection时从连接池中获取的,那么调用此方法,不会关闭连接,而是归还连接给数据库连接池。
  • 一般我们不需要去实现它,由数据库厂商来实现。
    ① C3P0:数据库连接池实现技术(比较老,Hibernate框架默认推荐C3P0作为连接池实现。)
    ② Druid:数据库连接池实现技术(由阿里巴巴提供,高效。)

2.C3P0数据库连接池技术

2.1 使用步骤

(1)导入jar包(两个)

  • c3p0-0.9.5.2.jar
  • mchange-commons-java-0.2.12.jar
  • 注意还有数据库驱动jar包:mysql-connector-java-8.0.11.jar
    在这里插入图片描述

(2)定义配置文件

  • 名称:c3p0.properties 或者 c3p0-config.xml
  • 存放路径:可以从下载的驱动包中,直接拷贝配置文件到src目录下即可。

(3)创建数据库连接池对象

DataSource ds = new ComboPooledDataSource();

(4)获取连接

Connection conn = ds.getConnection();

(5)归还连接

conn.close();

2.2 简单示例

(1)项目结构
在这里插入图片描述
(2)配置文件c3p0-config.xml

<?xml version="1.0" encoding="utf-8"?>
<c3p0-config>
  <!-- 默认配置 -->
  <default-config>
    <property name="driverClass">com.mysql.cj.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost:3306/ecargdb3?useSSL=false&amp;serverTimezone=UTC</property>
    <property name="user">root</property>
    <property name="password">109815</property>

    <!--连接池参数-->
    <!--初始化申请的连接数量-->
    <property name="initialPoolSize">5</property>
    <!--最大连接池数量-->
    <property name="maxPoolSize">10</property>
    <!--超时时间 3s-->
    <property name="checkoutTimeout">3000</property>
  </default-config>

  <!-- 有名称的配置,名称为otherc3p0 -->
  <named-config name="otherc3p0">
    <property name="driverClass">com.mysql.cj.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost:3306/ecargdb3?useSSL=false&amp;serverTimezone=UTC</property>
    <property name="user">root</property>
    <property name="password">109815</property>

    <!--连接池参数-->
    <!--初始化申请的连接数量-->
    <property name="initialPoolSize">5</property>
    <!--最大连接池数量-->
    <property name="maxPoolSize">8</property>
    <!--超时时间 3s-->
    <property name="checkoutTimeout">3000</property>
  </named-config>
</c3p0-config>

(3)Demo的Java实现C3P0Demo.java

package cn.ecarg.datasource.c3p0;

import com.mchange.v2.c3p0.ComboPooledDataSource;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;

/**
 * c3p0演示
 */
public class C3P0Demo {
    public static void main(String[] args) throws SQLException {
        //testNoNamedConfig();
        testNoNamedConfig();
    }

    public static void testNoNamedConfig() throws SQLException {
        //1.创建数据库连接池对象
        DataSource ds = new ComboPooledDataSource();
        //2.获取连接对象
        Connection conn = ds.getConnection();
        //3.打印
        System.out.println(conn);
		//归还连接
		conn.close();
    }

    public static void testNamedConfig() throws SQLException {
        //1 获取DataSource,使用指定名称配置
        DataSource ds = new ComboPooledDataSource("otherc3p0");
        for(int i = 0;i<8;i++){
            Connection conn = ds.getConnection();
            System.out.println(i+":"+conn);
        }
        //归还连接
        conn.close();
    }
}

3.Druid数据库连接池技术

3.1 使用步骤

(1)导入jar包

  • druid-1.0.9.jar
  • 注意还有数据库驱动jar包:mysql-connector-java-8.0.11.jar
    在这里插入图片描述

(2)定义配置文件

  • 配置文件为 xxx.properties
  • 可以叫任意名称,放在任意目录下

(3)加载properties文件

Properties pro = new Properties();
InputStream is = DruidDemo.class.getClassLoader().getResourceAsStream("druid.properties");
pro.load(is);

(4)获取数据库连接对象

DataSource ds = DruidDataSourceFactory.createDataSource(pro);

(5)获取连接

Connection conn = ds.getConnection();

(6)归还连接

conn.close();

3.2 简单示例

(1)配置文件druid.properties

driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/ecargdb2?userSSL=false&serverTimezone=UTC
username=root
password=109815
# 初始化连接数
initialSize=5
# 最大连接数
maxActive=10
# 最大超时时间
maxWait=3000
maxIdle=8
minIdle=3

(2)Demo的java实现DruidDemo.java

package cn.ecarg.datasource.druid;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.util.Properties;

/**
 * Druid演示
 */
public class DruidDemo {
    public static void main(String[] args) throws Exception {
        //1.导入jar包
        //2.定义配置文件.properties
        //3.加载配置文件
        Properties pro = new Properties();
        InputStream is = DruidDemo.class.getClassLoader().getResourceAsStream("druid.properties");
        pro.load(is);

        //4.获取连接池对象
        DataSource ds = DruidDataSourceFactory.createDataSource(pro);

        //5.获取连接
        Connection conn = ds.getConnection();
        System.out.println(conn);
        //6.归还连接
        conn.close();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值