88.【数据库连接池】

news/2024/5/18 23:27:27 标签: jdbc

概念

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

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

好处

  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

http://www.niftyadmin.cn/n/1850220.html

相关文章

89.【Spring JDBC】

Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发 步骤 1. 导入jar包 2. 创建JdbcTemplate对象。依赖于数据源DataSource JdbcTemplate template new JdbcTemplate(ds);例如: // 1.获取JdbcTemplate对象(放到成员变量位置上) private JdbcTemplate…

XI/PI 消息性能统计

PI 消息性能统计 Program:RSXMB_REMOTE_SERVICE 功能:用于统计、评估PI处理message效率,分析性能问题 Start Date:开始时间 No. of Days to Analyse:分析天数 Performance Statistics:是否进行性能统计&…

01.【MyBatis框架】

1. 前提 什么是框架 它是我们软件开发中的一套解决方案,不同的框架解决的是不同的问题。 使用框架的好处:框架封装了很多的细节,使开发者可以使用极简的方式实现功能。大大提高开发效率。 三层架构 表现层:是用于展示数据的业…

通用键盘快捷键JS函数封装

使用时直接调用:jQuery(document).bind(keydown, k,function (evt){         //此处写按快捷键执行的函数代码       });完整代码如下:/** jQuery Hotkeys Plugin* Copyright 2010, John Resig* Dual licensed under the MIT or GPL Ver…

02.【Mybatis基于注解的入门案例】

概述 步骤 把IUserDao.xml移除,在dao接口的方法上使用Select注解,并且指定SQL语句同时需要在SqlMapConfig.xml中的mapper配置时,使用class属性指定dao接口的全限定类名。 明确 我们在实际开发中,都是越简便越好,不…

Linux 文件夹 压缩 命令

Linux压缩文件的读取 *.Z compress 程序压缩的档案; *.bz2 bzip2 程序压缩的档案; *.gz gzip 程序压缩的档案; *.tar tar 程序打包的数据,并没有压缩过; *.tar.gz tar 程序打包…

关于python爬虫爬取小说

写了一个下载小说的爬虫,具体代码如下: 现在就是有一个问题,如何在不打乱章节顺序的情况下提高爬取的速度呢??? from urllib.parse import quote import requests from lxml import etree import timedef …

nginx状态监控

nginx状态监控 通过查看Nginx的并发连接,我们可以更清除的知道网站的负载情况。Nginx并发查看有两种方法(之所以这么说,是因为笔者只知道两种),一种是通过web界面,一种是通过命令,web查看要比命…