为什么需要连接池?
当数据库链接java的时候会出现以下三个阶段:
数据库链接-->执行完毕-->释放
而这个过程从链接到释放则会消耗非常大的资源,则出现了于java多线程中的线程池一样的池化技术.
池化技术: 准备一些预先的资源,过来就链接预先准备好的
开源数据源实现
使用了数据库连接池之后则在项目开发中就不需要再次编写链接数据库的代码 .
DBCP:
需要两个jar包:
commons-dbcp-1.4.jar与commons-pool-1.6.jar
下载地址:commons-pool.jar 和commons-dbcp.jar 下载地址_ljj123_的博客-CSDN博客_commons-pool.jar
配置文件:
# com.mysql.cj.jdbc.Driver
driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/app?characterEncoding=utf8&serverTimezone=Asia/Shanghai
username=root
password=98526
#<!-- 初始化连接 -->
initialSize=10
#最大连接数量
maxActive=50
#<!-- 最大空闲连接 -->
maxIdle=20
#<!-- 最小空闲连接 -->
minIdle=5
#<!-- 超时等待时间以毫秒为单位 6000毫秒/1000等于60秒 -->
maxWait=60000
#JDBC驱动建立连接时附带的连接属性属性的格式必须为这样:[属性名=property;]
#注意:"user" 与 "password" 两个属性会被明确地传递,因此这里不需要包含他们。
connectionProperties=useUnicode=true;characterEncoding=gbk
#指定由连接池所创建的连接的自动提交(auto-commit)状态。
defaultAutoCommit=true
#driver default 指定由连接池所创建的连接的事务级别(TransactionIsolation)。
#可用值为下列之一:(详情可见javadoc。)NONE,READ_UNCOMMITTED, READ_COMMITTED, REPEATABLE_READ, SERIALIZABLE
defaultTransactionIsolation=READ_UNCOMMITTED
代码:
package com.it_tets;
import org.apache.commons.dbcp.BasicDataSource;
import org.apache.commons.dbcp.BasicDataSourceFactory;
import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;
public class test1 {
private static DataSource basicDataSource=null;
static{
try {
//读取文件
InputStream resourceAsStream = test1.class.getClassLoader().getResourceAsStream("dbcpconfig.properties");//获取流
Properties properties = new Properties();
properties.load(resourceAsStream);//将流读取到
//创建数据源 工厂模式创建
basicDataSource = BasicDataSourceFactory.createDataSource(properties);//返回数据源
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 通过数据源获取链接
* @return 返回数据源
*/
public static Connection getConnection() throws SQLException {
return basicDataSource.getConnection();//从数据源中获取链接
}
}