数据库连接池简介
●数据库连接池是一个容器,负责分配、管理数据库连接
●它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个
●释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏
●好处:
➠资源重用
➠提升系统响应速度
➠避免数据库连接遗漏
数据库连接池实现
●标准接口:DataSource
➠官方(SUN)提供的数据库连接池标准接口,由第三方组织实现此接口。
➠功能:获取连接
●常见的数据库连接池:
➠DBCP
➠C3P0
➠Druid
●Druid(德鲁伊)
➠Druid连接池是阿里巴巴开源的数据库连接池项目
➠功能强大,性能优秀,是Java语言最好的数据库连接池之一
Driud使用步骤
1、导入jar包druid-1.1.12.jar
数据库连接池druid的jar包官网下载: https://mvnrepository.com/artifact/com.alibaba/druid
☞将其jar包导入当前模块目录下并设置当前模块有效
2、定义配置文件
☞配置文件的属性: https://github.com/alibaba/druid/wiki/DruidDataSource%E9%85%8D%E7%BD%AE%E5%B1%9E%E6%80%A7%E5%88%97%E8%A1%A8
(druid.properties配置文件)
driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/byshop?serverTimezone=PRC
username=root
password=123456
//初始化连接数量(容器中初始申请5个)
initialSize=5
//最小连接池数量
minIdle=1
//最大连接数
maxActive=10
//最大等待时间(10秒钟)超时后就会报错
maxWait=10000
timeBetweenEvictionRunsMillis=6000
//连接保持空闲而不被驱逐的最小时间
minEvictableIdleTimeMillis=300000
testWhileIdle=true
//用来检测连接是否有效的SQL,要求是一个查询语句,常用select 'x'。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会起作用。
validationQuery=select 1
3、加载配置文件
4、获取数据库连接池对象
5、获取连接
import com.alibaba.druid.pool.DruidDataSourceFactory;
import javax.sql.DataSource;
import java.io.FileInputStream;
import java.sql.Connection;
import java.util.Properties;
public class Druid {
public static void main(String[] args) throws Exception {
//加载配置文件——Properties对象加载配置文件
Properties prop=new Properties();
prop.load(new FileInputStream("src/druid.properties"));
//获取连接池对象
DataSource dataSource=DruidDataSourceFactory.createDataSource(prop);
//获取对应的数据库连接
Connection conn=dataSource.getConnection();
System.out.println(conn);
}
}
结果:(JDBC的一个连接对象)