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

相关内容

热门资讯

iq是不是安卓系统,安卓系统的... 你有没有想过,那个我们每天不离手的安卓系统,它是不是也有自己的智商呢?没错,今天咱们就来聊聊这个话题...
安卓系统短信存储上限,如何有效... 你有没有发现,手机里的短信越来越多,有时候翻看短信记录,竟然发现手机短信存储空间已经告急了!这可怎么...
秘客app安卓系统,探索未知领... 你有没有听说过那个超酷的秘客app安卓系统?最近,这款应用在互联网上可是火得一塌糊涂呢!它不仅功能强...
安卓系统 没有网卡驱动,安卓系... 你有没有遇到过这种情况:新入手了一台安卓手机,结果发现连上网络都成了难题,原来是没有安装网卡驱动!别...
安卓系统桌面时间显示,科技与美... 你有没有发现,手机屏幕上那个小小的时钟,它可是安卓系统桌面上的一个小秘密呢!它不仅告诉你时间,还能根...
安卓酒店影音系统app,打造智... 你有没有想过,在安卓手机上,如何让酒店的影音体验瞬间升级?没错,就是那个神奇的安卓酒店影音系统app...
安卓手机开发qq系统,功能解析... 你有没有想过,你的安卓手机里那个天天陪伴你的QQ系统,背后竟然有着如此丰富的开发历程和技巧呢?今天,...
海思芯片安卓系统,创新与突破的... 你知道吗?最近科技圈里有个大新闻,那就是海思芯片和安卓系统的那些事儿。这俩家伙可是科技界的明星,今天...
安卓系统 时间改变颜色,安卓系... 你知道吗?手机里的安卓系统竟然能根据时间改变颜色,这听起来是不是有点神奇?想象当清晨的第一缕阳光透过...
安卓智能音乐播放系统,打造个性... 你有没有发现,随着智能手机的普及,音乐已经不再只是单纯地通过耳机享受了?现在,安卓智能音乐播放系统可...
安卓系统学习书籍,从入门到精通 你有没有想过,想要深入了解安卓系统,却苦于没有一本合适的书籍呢?别急,今天我就要给你推荐几本市面上口...
支持电脑的安卓系统,探索安卓系... 你有没有想过,你的电脑竟然也能用安卓系统?没错,就是那个我们手机上常用的安卓系统,现在竟然也能在电脑...
iphone系统安卓手机壳,时... 你有没有发现,最近你的手机壳是不是已经有点儿跟不上潮流了呢?别急,今天就来给你揭秘为什么iPhone...
vivo升级安卓9.0系统,畅... 哇,亲爱的手机控们,是不是最近你的vivo手机突然变得聪明了许多?没错,vivo最近给我们的手机宝宝...
安卓的系统好用吗,体验与优缺点... 你有没有想过,为什么安卓系统这么受欢迎呢?它到底好用到什么程度呢?今天,就让我带你从多个角度来揭秘这...
u盘系统 安卓系统安装教程,U... 你是不是也和我一样,对安卓系统情有独钟,想要在U盘上安装它,随时随地享受安卓的魅力?别急,今天就来手...
安卓系统复制文字颜色,复制文字... 你有没有遇到过这样的烦恼:在安卓手机上复制一段文字,结果颜色也跟着一起复制过去了,让人看着不舒服,还...
安卓系统7.0怎么截图,轻松掌... 你有没有想过,有时候手机上的某个瞬间,你想要永久保存下来呢?比如,一个搞笑的表情包,或者一个重要的信...
安卓改写底层系统,揭秘系统架构... 你有没有想过,你的安卓手机其实就像一个巨大的宝藏,里面藏着无数的奥秘?今天,就让我带你一探究竟,揭开...
北斗系统支持安卓系统吗,助力智... 你有没有想过,咱们国家的北斗系统是不是也能在安卓手机上大显神威呢?这可是个让人好奇的问题,毕竟现在安...