连接池dbcp
连接池dbcp
DBCP:apache组织
使用步骤:
			  1.导入jar包(commons-dbcp-1.4.jar和commons-pool-1.5.6.jar、commons-logging-1.2.jar)
			  2.使用api
a.硬编码
					  //创建连接池
					  BasicDataSource ds = new BasicDataSource();
  //配置信息
					  ds.setDriverClassName("com.mysql.jdbc.Driver");
					  ds.setUrl("jdbc:mysql:///day07");
					  ds.setUsername("root");
					  ds.setPassword("1234");
代码展示:
1.创建一个项目DataSourse,创建一个包com.dbcp.hjh
2.在包下创建一个类DBCPTest1.java
3.新建一个lib用来存放jar包(commons-dbcp-1.4.jar commons-pool-1.5.6.jar commons-logging-1.2.jar),导入后buildpat

代码运行之前数据库数据如下:

java代码如下:
JDBCUtil.java代码:
package com.util.hjh; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class JDBCUtil {
final static String driver = "com.mysql.jdbc.Driver";
final static String url = "jdbc:mysql://localhost/hejh?useUnicode=true&characterEncoding=UTF-8";
final static String user = "root";
final static String password = "root"; Connection conn = null;
PreparedStatement ps = null;
Statement st = null;
ResultSet rs = null; /**获取连接*/
public static Connection getConnection() throws SQLException {
Connection conn = null;
try {
//注册驱动
Class.forName(driver);
//获取连接
conn = DriverManager.getConnection(url, user, password);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return conn;
} /**关闭资源closeResourse(conn,st)*/
public static void closeResourse(Connection conn,Statement st) {
try {
if(st!=null) {
st.close();
}else {
st = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if(conn!=null) {
conn.close();
}else {
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
} /**关闭资源closeResourse(conn,ps)*/
public static void closeResourse(Connection conn,PreparedStatement ps) {
try {
if(ps!=null) {
ps.close();
}else {
ps = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if(conn!=null) {
conn.close();
}else {
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
}
/**关闭资源closeResourse(rs)*/
public static void closeResourse(ResultSet rs) {
try {
if(rs!=null) {
rs.close();
}else {
rs = null;
}
} catch (SQLException e) {
e.printStackTrace();
}finally { }
}
}
DBCPTest1.java代码如下:
package com.dbcp.hjh; import java.sql.Connection;
import java.sql.PreparedStatement;import org.apache.commons.dbcp2.BasicDataSource;
import org.junit.Test;
import com.util.hjh.JDBCUtil; public class DBCPTest1 { @Test
public void test() throws Exception {
//创建连接池
BasicDataSource ds = new BasicDataSource(); //配置信息
ds.setDriverClassName("com.mysql.jdbc.Driver");
ds.setUrl("jdbc:mysql://localhost/jdbc");
ds.setUsername("root");
ds.setPassword("root"); //连接数据库操作
Connection conn = ds.getConnection();
String sql = "insert into student values(?,?,?)";
PreparedStatement ps= conn.prepareStatement(sql);
//设置参数
ps.setInt(1, 10);
ps.setString(2, "yz");
ps.setInt(3, 95); int i = ps.executeUpdate();
System.out.println("插入了"+i+"行数据"); //关闭资源
JDBCUtil.closeResourse(conn, ps);
}
}
代码运行后数据库数据显示为:在jdbc数据库中student表,新增了一条id为10的数据

b.配置文件
					  实现编写一个properties文件
					  //存放配置文件
					  Properties prop = new Properties();
					  prop.load(new FileInputStream("src/dbcp.properties"));
					  //设置
					  //prop.setProperty("driverClassName", "com.mysql.jdbc.Driver");
  //创建连接池
					  DataSource ds = new BasicDataSourceFactory().createDataSource(prop);
代码介绍:
1.创建一个项目DataSourse,创建一个包com.dbcp.hjh
2.在包下创建一个类DBCPTest2.java
3.新建一个lib用来存放jar包(commons-dbcp-1.4.jar commons-pool-1.5.6.jar commons-logging-1.2.jar),导入后buildpat
4.新建一个配置文件dbcp.properties

dbcp.properties内容:
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost/jdbc
username=root
password=root
工具类JDBCUtil.java源码如下:
package com.util.hjh; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class JDBCUtil {
final static String driver = "com.mysql.jdbc.Driver";
final static String url = "jdbc:mysql://localhost/hejh?useUnicode=true&characterEncoding=UTF-8";
final static String user = "root";
final static String password = "root"; Connection conn = null;
PreparedStatement ps = null;
Statement st = null;
ResultSet rs = null; /**获取连接*/
public static Connection getConnection() throws SQLException {
Connection conn = null;
try {
//注册驱动
Class.forName(driver);
//获取连接
conn = DriverManager.getConnection(url, user, password);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return conn;
} /**关闭资源closeResourse(conn,st)*/
public static void closeResourse(Connection conn,Statement st) {
try {
if(st!=null) {
st.close();
}else {
st = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if(conn!=null) {
conn.close();
}else {
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
} /**关闭资源closeResourse(conn,ps)*/
public static void closeResourse(Connection conn,PreparedStatement ps) {
try {
if(ps!=null) {
ps.close();
}else {
ps = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if(conn!=null) {
conn.close();
}else {
conn = null;
}
} catch (SQLException e) {
e.printStackTrace();
}
}
/**关闭资源closeResourse(rs)*/
public static void closeResourse(ResultSet rs) {
try {
if(rs!=null) {
rs.close();
}else {
rs = null;
}
} catch (SQLException e) {
e.printStackTrace();
}finally { }
}
}
DBCPTest2.java源码如下:
package com.dbcp.hjh; import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.util.Properties;
import javax.sql.DataSource;
import org.apache.commons.dbcp2.BasicDataSourceFactory;
import org.junit.Test;
import com.util.hjh.JDBCUtil; public class DBCPTest2 { @Test
public void test() throws Exception { //存放配置文件
Properties pp = new Properties();
pp.load(new FileInputStream("src/dbcp.properties")); //创建连接池
DataSource ds = new BasicDataSourceFactory().createDataSource(pp); Connection conn = ds.getConnection();
String sql = "insert into student values(?,?,?)";
PreparedStatement ps = conn.prepareStatement(sql);
ps.setInt(1, 5);
ps.setString(2, "zys");
ps.setInt(3, 88);
int i = ps.executeUpdate();
System.out.println("插入了"+i+"条数据"); //释放资源
JDBCUtil.closeResourse(conn, ps);
}
}
数据库数据显示为:

连接池dbcp的更多相关文章
- jdbc数据连接池dbcp要导入的jar包
		
jdbc数据连接池dbcp要导入的jar包 只用导入commons-dbcp-x.y.z.jarcommons-pool-a.b.jar
 - 连接池 DBCP c3p0以及分页的案例
		
1. 连接池 思考: 程序中连接如何管理? 连接资源宝贵:需要对连接管理 连接: a) 操作数据库,创建连接 b) 操作结束, 关闭! 分析: 涉及频繁的连接的打开.关闭,影响程序的运行效率! 连接 ...
 - java JDBC (八) 连接池 DBCP
		
package cn.sasa.demo1; import javax.sql.DataSource; import org.apache.commons.dbcp2.BasicDataSource; ...
 - 03 事务,连接池DBCP,C3P0,DBUtils
		
事务 Transaction 其实指的一组操作,里面包含许多个单一的逻辑.只要有一个逻辑没有执行成功,那么都算失败. 所有的数据都回归到最初的状态(回滚) 事务的作用:为了确保逻辑的成功. 例子: ...
 - 在jdbc基础上进阶一小步的C3p0 连接池(DBCP 不能读xml配置文件,已淘汰) 和DBUtils 中两个主要类QueryRunner和ResultSetHandler的使用
		
首先看C3p0这个连接池,最大优势可以自动读取默认的配置文件 <?xml version="1.0" encoding="UTF-8"?> < ...
 - 连接池dbcp  pool
		
-package cn.gdpe.pool; import java.io.InputStream;import java.sql.Connection;import java.sql.Prepare ...
 - DBCP、c3p0、Druid三大连接池区别
		
DBCP.c3p0.Druid三大连接池区别 一.连接池优势 如果一个项目中如果需要多个连接,如果一直获取连接,断开连接,这样比较浪费资源: 如果创建一个池,用池来管理Connection,这样就可以 ...
 - 一次dbcp和Hikaricp连接池比较联想到的线程池
		
最近在测试连接池dbcp和Hikaricp速度时,为了弄清楚Hikaricp速度优势的原因,阅读了二者的源码,源码不是很难,类也没有多少,联想到很多知识,现在来总结一下.
 - Java连接池详解
		
于共享资源,有一个很著名的设计模式:资源池(Resource Pool).该模式正是为了解决资源的频繁分配﹑释放所造成的问题.为解决我们的问题,可以采用数据库连接池技术.数据库连接池的基本思想就是为数 ...
 
随机推荐
- touch滑动事件---简单小案例
			
html: <!--导航栏头部--><div class="type_nav"> <ul class="clearfix " v- ...
 - Web充斥着存在漏洞的过期JavaScript库
			
虽然使用第三方软件库通常会降低开发的时间,但同时也会增加网站暴露出的攻击表面,对此我们应有充分的认识.因此需要保持第三方软件库的最新版本依赖,以便从安全更新中获益.即便如此,一份近期研究表明,在Ale ...
 - 查看JDK的安装路径 和 安装版本
			
查看JDK的安装路径: 打开 运行,输入 cmd . 输入: java -verbose (ps:java后面必须敲一个空白格) 得到下图: 最后的两行, ...
 - 网络编程-基础篇03(I/O模型)
			
好文传播,在此插个眼: 一文读懂高性能网络编程中的I/O模型
 - svn查看指定版本提交信息的命令
			
通过svn命令查看指定版本提交的文件和日志信息 svn log -r ARG -v ARG :版本 可以是如下之一: NUMBER 版本号 '{' DATE '}' 在指定时间以后的版本 'HEAD' ...
 - jQuery 取值、赋值的基本方法整理
			
/*获得TEXT.AREATEXT的值*/ var textval = $("#text_id").attr("value"); //或者 var textva ...
 - 2018-8-17-C#-从零开始写-SharpDx-应用-控制台创建-Sharpdx-窗口
			
title author date CreateTime categories C# 从零开始写 SharpDx 应用 控制台创建 Sharpdx 窗口 lindexi 2018-8-17 9:3:3 ...
 - 转载:腾讯与新浪的通过IP地址获取当前地理位置(省份)的接口
			
腾讯的接口是 ,返回数组 http://fw.qq.com/ipaddress 返回值 var IPData = new Array("61.135.152.194"," ...
 - TZ_15Spring-Cloud_Eureka-Ribbon-Hystix-Feign-Zuul微服务整合
			
1.一个微服务框架的基本流程 2.Eureka --Feign-Zuul Eureka:就是服务注册中心(可以是一个集群),对外暴露 ...
 - Functional Programming Contest - September'14
			
比赛链接 A题 -- Enter your code here. Read input from STDIN. Print output to STDOUT main = do x <- get ...