JavaWeb简单实例——DBCP数据库连接池
admin
2024-04-12 10:41:28
0

简单介绍:

关于数据库连接池的基本概念我们上次在德鲁伊数据库连接池的章节已经做过基本介绍了,其实数据库连接池的理念非常的好理解,当我们在普通模式进行数据库连接的时候,每次都在使用过后都在最后释放了资源,断开了连接。这只是我们在测试的时候单个服务器连接数据库,但是在我们的实际开发中,会有很多的客户端来连接我们的数据库,如果在这种时候依然在每次连接的时候都创建一个新的连接,然后在访问结束之后断开连接,也就是销毁这个连接,对于服务器的资源的占用是非常大的,所以,数据库连接池的概念就是我们每次建立连接后,并不是马上销毁,而是放在一个缓冲池中,当下一次连接到来的时候再次使用,这样就能节省我们的连接时候的资源。

官方定义叫做,数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用现有的数据库连接,而不是重新创建

需要的依赖包:

使用DBCP数据库连接池需要使用到两个依赖包,一个是DBCP本体,一个是DBCP的依赖包Pool

DBCP依赖包下载地址:

DBCP – 下载 Apache Commons DBCP

Pool依赖包下载地址:

池 – 下载 Apache 共享资源池

DBCP数据库连接池:

DataSource接口:

在获取数据库连接的时候,不一定要使用DriverManager,Java提供了另一种数据库连接方式,通过实现DataSource来完成连接,具体是怎么实现的连接,Java显然并不希望我们去探究底层,只需要让我们知道怎么使用就可以了。

实现类:BasicDataSource

DBCP通过一个BasicDataSource类来完成连接参数的配置和数据库连接的获取

工厂类:

工厂类的出现的其中一个作用是传入一个Properties对象,通过这个对象设置连接参数信息,并通过读取连接信息的方式获取数据库连接。这样做的好处就是在代码中没有明显的数据库连接信息,比如用户名和密码等等敏感信息,并且防止硬编码。

工厂类:BasicDataSourceFactions

获取对象方法:BasicDataSourceFactions#createBasicDataSource()

Java的工厂模式:

在Java中,有一种创建对象的模式叫做工厂模式。大致理解为,当我们在创建某一对象的时候,我们通过工厂类的方法返回对象的方式来创建,而这个工厂类可以创建很多对象,而我们要具体的创建某一个具体的对象的时候通过创建工厂类的某一子类的方式,将创建对象的细节传递给了某一子类。这么做的好处是使用户从具体的产品对象中解耦。

代码示例:

在代码中设置连接参数:

package Semester_3.src;import org.apache.commons.dbcp2.BasicDataSource;import java.sql.Connection;
import java.sql.SQLException;public class DBCPDemo {public static void main(String[] args) throws SQLException {
//        使用BasicDataSource具体实现类来连接数据库BasicDataSource bds = new BasicDataSource();
//        设置各种数据库连接参数bds.setDriverClassName("com.mysql.cj.jdbc.Driver");bds.setUsername("root");bds.setUrl("jdbc:mysql:///jdbc");bds.setPassword("123456");
//        获取连接和连接信息Connection connection = bds.getConnection();System.out.println("数据库连接信息:"+connection);System.out.println("链接地址:"+bds.getUrl());System.out.println("用户名:"+bds.getUsername());System.out.println("密码:"+bds.getPassword());System.out.println("数据库驱动类:"+bds.getDriver());System.out.println("数据库连接类:"+bds.getDriverClassName());}
}

从配置文件中读取参数:

配置文件:

配置文件的编写我们之前在德鲁伊数据库连接池的操作中已经写过一次了,基本都是一样的

driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql:///jdbc
username=root
password=123456
initialSize=5
maxIdle=10

代码实现:

public static void connPro() throws Exception {
//        创建配置文件读取对象Properties p = new Properties();
//        创建配置文件的文件输入流InputStream in = Files.newInputStream(Paths.get("Java/src/Semester_3/src/Util_10/connEtc.properties"));
//        将配置文件加载到对象中p.load(in);
//        将Properties对象放置到创建链接的方法中,这个操作就相当于之前的一堆set方法BasicDataSource bds = BasicDataSourceFactory.createDataSource(p);
//        然后就是获取连接以及打印连接信息Connection conn = bds.getConnection();System.out.println("数据库连接信息:"+conn);System.out.println("链接地址:"+bds.getUrl());System.out.println("用户名:"+bds.getUsername());System.out.println("密码:"+bds.getPassword());System.out.println("数据库驱动类:"+bds.getDriver());System.out.println("数据库连接类:"+bds.getDriverClassName());}

注意点:

其实这个数据库连接池的使用只需要知道使用方法就好,主要是记住类名,方法名就好,然后就是关于jar包的下载和导入

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...