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包的下载和导入

相关内容

热门资讯

安卓系统音乐软件推荐,五大热门... 你有没有发现,手机里音乐软件那么多,挑一款适合自己的真心不容易啊!安卓系统上的音乐软件更是五花八门,...
安卓系统刷三星系统,轻松刷入最... 你有没有想过,你的安卓手机其实可以变身成三星的旗舰机呢?没错,就是那种屏幕大、性能强、系统流畅的旗舰...
塞班系统可以转为安卓,跨越时代... 你知道吗?现在科技的发展真是让人眼花缭乱,连我们曾经熟悉的塞班系统也能华丽转身,变成安卓系统呢!是不...
安卓系统如何录像剪辑,录像剪辑... 亲爱的手机控们,你是否有过这样的经历:在某个瞬间,你捕捉到了一段令人难忘的画面,却因为没来得及记录而...
安卓系统强行提高配置,配置提升... 最近你的安卓手机是不是感觉有点儿“发烧”了?没错,就是那种配置突然“升级”的感觉。你是不是也觉得,手...
安卓系统能做设计吗,探索安卓系... 你有没有想过,安卓系统竟然也能做设计?是的,你没听错,这个我们日常使用的手机操作系统,竟然也能成为设...
安卓系统几年后使用,探索多年使... 你有没有想过,那些陪伴我们多年的安卓手机,它们现在过得怎么样了呢?安卓系统,这个曾经让我们爱恨交加的...
平板安卓苹果双系统,安卓与苹果... 你有没有想过,拥有一台既能运行安卓系统,又能使用苹果系统的平板电脑,那该是多么酷炫的事情啊!想象一边...
嘉和病历系统安卓,便捷医疗信息... 你有没有听说过嘉和病历系统安卓版?这可是医疗行业的一大神器呢!想象医生们拿着手机就能轻松管理病历,患...
安卓10更改系统号,揭秘系统编... 你知道吗?最近安卓系统又来了一次大更新,安卓10正式上线了!这次更新可是带来了不少新功能,其中最引人...
小米墨水屏 安卓系统,融合科技... 你知道吗?在科技日新月异的今天,电子阅读器市场也迎来了新的活力。而小米,这个我们熟悉的品牌,最近推出...
系统软件最少的安卓系统,基于最... 你有没有想过,手机系统就像是我们生活的操作系统,有时候太复杂了,让人感觉头都大了。今天,我要给你介绍...
安卓系统关闭应用推荐,安卓系统... 你有没有发现,手机里的安卓系统最近有点儿“小情绪”,总是给你推荐一些你根本不感兴趣的应用?别急,今天...
车载安卓系统如何用,智能驾驶体... 你有没有想过,你的车载安卓系统其实是个隐藏的宝库呢?没错,就是那个你每天开车时几乎不离手的那个屏幕,...
安卓系统更新如何取消,```p... 你有没有遇到过这种情况:安卓手机的系统更新推送得让人有点头疼,有时候更新后的系统还各种不适应。别急,...
安卓系统源码修改练习,从零开始... 亲爱的技术爱好者,你是否曾梦想过深入安卓系统的内核,亲手修改源码,让手机变得更加个性化?那就让我们一...
安卓考勤系统论文,基于安卓平台... 你有没有想过,每天打卡上班,是不是也能变得有趣起来呢?没错,就是那个我们每天都要面对的安卓考勤系统。...
安卓系统哪家流畅度,安卓系统流... 手机里的安卓系统,就像是每个人的小世界,各有各的风采。但说到流畅度,这可是大家最关心的问题了。今天,...
安卓开不了定位系统,安卓设备定... 最近是不是发现你的安卓手机定位系统突然罢工了?别急,别慌,今天就来给你详细解析一下这个问题,让你轻松...
安卓系统怎么设置airpod,... 你有没有发现,自从AirPods问世以来,它就成为了科技界的宠儿?这款无线耳机不仅音质出众,而且连接...