88.【数据库连接池】

概念

其实就是一个容器(集合),存放数据库连接的容器。

当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象,用户访问完之后,会将连接对象归还给容器。

好处

  1. 节约资源
  2. 用户访问高效

实现

  • 标准接口:javax.sqlDataSource

方法

获取连接
getConnection()
归还连接

如果连接对象Connection是从连接池中获取的,那么调用Connection.close()方法,则不会再关闭连接了,而是归还连接。

Connection.close()

一般我们不去实现它,有数据库厂商来实现

  • C3P0:数据库连接池技术
  • Druid:数据库连接池实现技术,由阿里巴巴提供的

C3P0:数据库连接池技术

步骤

1.导入jar包

两个:c3p0-0.9.5.2.jarmchange-commons-java-0.2.12.jar

  • 不要忘记导入数据库驱动jar包 mysql-connector-java-5.1.37-bin
2. 定义配置文件

名称:c3p0.properties或者c3p0-config.xml

在src目录使用这两个名字会自动获取配置文件

路径:直接将文件放在src目录下即可。

3. 创建核心对象:数据库连接池对象 ComboPooledDataSource
  DataSource ds  = new ComboPooledDataSource();
4. 获取连接:getConnection
1.  Connection conn = ds.getConnection();

Druid:数据库连接池实现技术,由阿里巴巴提供

步骤

1. 导入jar包 druid-1.0.9.jar
2. 定义配置文件
  • properties形式的
  • 可以叫任意名称,可以放在任意目录下
3. 加载配置文件 :Properties
Properties pro = new Properties();
InputStream is = DruidDemo1.class.getClassLoader()
            .getResourceAsStream("druid.properties");
pro.load(is);
4. 获取数据库连接池对象:通过工厂来来获取 DruidDataSourceFactory
DataSource ds = DruidDataSourceFactory.createDataSource(pro);
5. 获取连接:getConnection
  Connection conn = ds.getConnection();

定义工具类

  1. 定义一个类 JDBCUtils
  2. 提供静态代码块加载配置文件,初始化连接池对象
  3. 提供方法
    • 获取连接方法:通过数据库连接池获取连接
    • 释放资源
    • 获取连接池的方法
package cn.luis.utils;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

/**
 * @ClassName JDBCUtils
 * @Description Druid连接池的工具类
 * @Author L
 * @Date 2020.01.18 21:20
 * @Version 1.0
 * @Remark TODO
 **/
public class JDBCUtils {

    // 1.定义成员变量 DataSource
    private static DataSource ds;
    static {

        try {
            // 2.加载配置文件
            Properties pro = new Properties();
            pro.load(JDBCUtils.class.getClassLoader()                                                 .getResourceAsStream("druid.properties"));
            // 3.获取DataSource
            ds = DruidDataSourceFactory.createDataSource(pro);
        } catch (IOException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /*
        获取连接
     */
    public static Connection getConnection() throws SQLException {
        return ds.getConnection();
    }

    /*
       释放资源
     */
    public static void close(Statement stmt, Connection conn) {
        close(null,stmt,conn);
    }

    /*
       释放资源
     */
    public static void close(ResultSet rs, Statement stmt, Connection conn) {
        if(rs != null) {
            try {
                rs.close(); //归还连接
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if(stmt != null) {
            try {
                stmt.close(); //归还连接
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if(conn != null) {
            try {
                conn.close(); //归还连接
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    /*
       获取连接池方法
     */
    public static DataSource getDataSource() {
        return ds;
    }
}

练习

使用新的工具类,完成添加操作,给db3中的account表中添加一条记录

package cn.luis.DataSource.druid;

import cn.luis.utils.JDBCUtils;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

/**
 * @ClassName DruidDemo2
 * @Description 使用新的工具类
 * @Author L
 * @Date 2020.01.18 21:42
 * @Version 1.0
 * @Remark 完成添加操作,给db3中的account表中添加一条记录
 **/
public class DruidDemo2 {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pstmt = null;

        try {
            // 1.获取连接
            conn = JDBCUtils.getConnection();
            // 2.定义sql
            String sql = "insert into account values(null,?,?)";
            // 3.获取pstmt对象
            pstmt = conn.prepareStatement(sql);
            // 4.赋值
            pstmt.setString(1,"gangtiexia");
            pstmt.setDouble(2,3000);
            // 5.执行sql
            int count = pstmt.executeUpdate();
            System.out.println(count);
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            // 6.释放资源
            JDBCUtils.close(pstmt,conn);
        }

    }
}

结果:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值