03_dbcp数据源依赖jar包,DBCP中API介绍,不同过dbcp方式使用dbcp数据库连接池,通过配置文件使用dbcp数据库连接池
DBCP数据源
使用DBCP数据源,需要导入两个jar包
Commons-dbcp.jar:连接池的实现
Common-pool.jar:连接池实现的依赖库。
导入mysql的jar包。
DBCP核心API
BasciDataSource
它可以通过实例化对象的方式获得一个对象。
它里面有如下方法:
setDriverClassName(String driverClassName)
设置驱动类的名称。
setInitialSize(int initialSize)
设置初始化时的链接数目。
setMaxActive(int maxIdle)
设置最大的并发访问数量。
setMaxIdle(int maxIdle):
设置最大的闲置数目。
setPassword:用于设置密码。
setUrl:设置url
setUsername:设置用户名。
数据源实现BasicDataSourceFactory
用于创建数据源的工厂类,
不设配置文件时使用BasicDataSource的程序的写法:
package cn.toto.utils;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.sql.DataSource;
import org.apache.commons.dbcp.BasicDataSource;
public
class JdbcUtils {
private JdbcUtils(){}
//定义BasicDataSource的父类接口的形式,获得ds的参数。
private
static DataSource
ds;
static {
//要想使用写好的数据源的功能,得先初始化一个dbcp连接池
BasicDataSource bds = new BasicDataSource();
//设置一系列参数
bds.setDriverClassName("com.mysql.jdbc.Driver");
bds.setUrl("jdbc:mysql://localhost:3306/day14");
bds.setUsername("root");
bds.setPassword("123456");
//设置初始化大小
bds.setInitialSize(5); //个连接数
bds.setMaxActive(20);//设置并发访问数目。
//bds.setMaxWait(0);//设置最大等待时间。不等待。
ds = bds;
//获得数据是通过父接口的DataSource接口。
}
//获得连接池
public
static DataSource getDataSource(){
return
ds;
}
//获得与指定数据库的连接
public
static Connection getConnection()
throws SQLException{
//从连接池返回一个连接
return
ds.getConnection();
}
public
static
void release(ResultSet rs,Statement stmt,Connection conn){
if(rs!=null)
{
try{
rs.close();
}catch(SQLException e){
e.printStackTrace();
}
rs = null;
}
if(stmt!=null){
try{
stmt.close();
}catch(SQLException e){
e.printStackTrace();
}
stmt = null;
}
if(conn!=
null) {
try{
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
conn = null;
}
}
}
用于验证的主函数的写法:
package cn.toto.demo;
import java.sql.Connection;
import java.sql.SQLException;
import cn.toto.utils.JdbcUtils;
public
class Demo {
public
static
void main(String[] args)
throws SQLException {
for(int
i=0;i<30;i++){
Connection conn = JdbcUtils.getConnection();//如果只写这句,程序将一直等待执行。
System.out.println(conn);//条
conn.close();//条数据。
}
}
}
在文档中还有一个方法:
org.apache.commons.dbcp
Class BasicDataSourceFactory它里面有一个这样的方法:
createDataSource(Properties properties)
Creates andconfigures a BasicDataSourceinstance
based on the given properties.
它是根据Properties,根据properties中的信息获得信息。
配置dbcp的配置文件的方法是:找到文档中的Configuration,里面有多个属性。
在src下面编写一个一个配置文件config.properties
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/day14
username=root
password=123456
initialSize=5
maxiActive=20
通过配置文件的方式获得的数据源的源码是:
package cn.toto.utils;
import
java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;
import javax.sql.DataSource;
import
org.apache.commons.dbcp.BasicDataSource;
import org.apache.commons.dbcp.BasicDataSourceFactory;
public
class JdbcUtils {
private JdbcUtils() {
}
//
定义BasicDataSource的父类接口的形式,获得ds的参数。
private
static DataSource
ds;
static {
try {
InputStream in = JdbcUtils.class.getClassLoader().getResourceAsStream(
"config.properties");//通过类加载的方式获得获得配置文件的流
Properties prop = new Properties();
prop.load(in);//通过流将配置项加载进来。
//通过工厂类读取
ds = BasicDataSourceFactory.createDataSource(prop);
} catch (Exception e) {
throw
new ExceptionInInitializerError();
}
}
//
获得连接池
public
static DataSource getDataSource() {
return
ds;
}
//
获得与指定数据库的连接
public
static Connection getConnection()
throws SQLException {
//
从连接池返回一个连接
return
ds.getConnection();
}
public
static
void release(ResultSet rs, Statement stmt, Connection
conn) {
if (rs !=
null) {
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
rs = null;
}
if (stmt !=
null) {
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
stmt = null;
}
if (conn !=
null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
conn = null;
}
}
}
03_dbcp数据源依赖jar包,DBCP中API介绍,不同过dbcp方式使用dbcp数据库连接池,通过配置文件使用dbcp数据库连接池的更多相关文章
- maven依赖本地非repository中的jar包-依赖jar包放在WEB-INF/lib等目录下的情况客户端编译出错的处理
MAVEN 今天在使用maven编译打包一个web应用的时候,碰到一个问题: 项目在开发是引入了依赖jar包,放在了WEB-INF/lib目录下,并通过buildpath中将web libariary ...
- maven依赖jar包更新,业务jar需同步更新(业务jar依赖API)
背景: 环境出现问题,定位为依赖jar缺失,修改工程pom文件补充依赖jar. 更新要点说明: 依赖jar,更新提交 业务jar,也需更新提交:maven构建会把依赖jar引用进去,更新环境如果单独更 ...
- maven下载依赖jar包失败处理方法--下载jar包到本地并安装到maven仓库中
所有maven依赖jar包地址:https://repo1.maven.org/maven2/org/apache/ 1. 安装jar包失败报错: The following artifacts co ...
- 解决Gradle生成Eclipse支持后,发布到Tomcat丢失依赖jar包的问题
最近一个项目中,使用号称下一代构建工具的Gradle构建项目. 使用中发现一个问题,Gradle从中央库下载的jar文件在系统的其它目录,使用gradle eclipse添加Eclipse支持时,ja ...
- Eclipse下新建Maven项目、自动打依赖jar包
当我们无法从本地仓库找到需要的构件的时候,就会从远程仓库下载构件至本地仓库.一般地,对于每个人来说,书房只有一个,但外面的书店有很多,类似第,对于Maven来说,每个用户只有一个本地仓库,但可以配置访 ...
- [Maven]Maven构建可执行的jar包(包含依赖jar包)
----------------------------------------------------------------- 原创博文,如需转载请注明出处! 博主:疲惫的豆豆 链接:http:/ ...
- Maven的assembly插件实现自定义打包部署(包含依赖jar包)
微服务必备 优点: 1.可以直接导入依赖jar包 2.可以添加插件启动 .sh 文件 3.插件的配置以及微服务的统一打包方式 1.首先我们需要在pom.xml中配置maven的assembly插件 & ...
- Maven下载项目依赖jar包和使用方法
一.Maven3.5.0安装与配置+Eclipse应用 参考:Maven3.5.0安装与配置+Eclipse应用 二.http://mvnrepository.com/ 此处以http://mvnre ...
- Eclipse下Maven新建项目、自动打依赖jar包(包含普通项目和Web项目)
不多说,直接上干货! 当我们无法从本地仓库找到需要的构件的时候,就会从远程仓库下载构件至本地仓库.一般地,对于每个人来说,书房只有一个,但外面的书店有很多,类似第,对于Maven来说,每个用户只有一个 ...
随机推荐
- [HNOI2010]PLANAR
题目描述 若能将无向图G=(V,E)画在平面上使得任意两条无重合顶点的边不相交,则称G是平面图.判定一个图是否为平面图的问题是图论中的一个重要问题.现在假设你要判定的是一类特殊的图,图中存在一个包含所 ...
- 【BZOJ2186】【SDOI2008】沙拉公主的困惑
Description 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞票.房地产第一大户沙拉公主决定预测一下大富翁 ...
- ●BZOJ 2560 串珠子
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2560 题解: 容斥,状压计数dp 首先求出一个数组 g[s] 表示集合内的点的连边方案数(两 ...
- bzoj1926[Sdoi2010]粟粟的书架 二分 主席树
1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MBSubmit: 1064 Solved: 421[Submit][Stat ...
- Linux 基本概念和操作
我们在使用Linux时,不是直接和系统打交道,而是通过shell的中间程序.在图形界面下为了实现窗口的输入和输出,linux系统为我们提供了终端模拟器Terminal,常见的终端模拟器有 gnome- ...
- Java的数组排序
对数组进行排序 使用到的排序算法有: 1 选择排序 2 冒泡排序 3 插入排序 4 JavaAPI提高排序算法 选择排序的原理: 1 将数组中每个元素与第一个元素比较,如果这个元素小于第 ...
- 优化Webpack打包速度
1. Webpack 可以配置 externals 来将依赖的库指向全局变量,从而不再打包这个库,比如对于这样一个文件: import React from 'react'; console.lo ...
- vue之生命周期
vue的生命周期的过程提供了我们执行自定义逻辑的机会,好好理解它的生命周期,对我们很有帮助. 1.vue实例的生命周期(vue2.0) 2.生命周期描述:(参考截图) 3.例子 window.vm = ...
- 【转载】RAID写惩罚(Write Penalty)与IOPS计算
浅谈RAID写惩罚(Write Penalty)与IOPS计算 Character is what you are in the dark. 暗处最能反映一个人真正品格. ---------Apri ...
- Python3 循环
Python中的循环语句有 for 和 while. Python循环语句的控制结构图如下所示: while 循环 Python中while语句的一般形式: while 判断条件: statement ...