JDBC连接池&DBUtils
JDBC连接池
DBCP:Apache推出的Database Connection Pool
使用步骤:
> 添加jar包 commons-dbcp-1.4.jar commons-pool-1.5.6.jar
l 创建DBCP连接池工具类
n 规范接口:javax.sql.DataSource接口
n 实现类:BasicDataSource, 重写接口中的方法getConnection()
使用读取配置文件的方式(加案例)
DBCP中有一个工厂类BasicDataSourceFactory
工厂类中有一个静态方法
static DataSource createDataSource(Properties prop)
此方法返回的就是DataSource接口的实现类对象BasicDataSource
创建Propertis集合+IO技术读取配置文件
把配置文件传入BasicDataSourceFactory静态方法createDataSource中
public class DBCPUtilsReadConfig {
private static DataSource dataSourse;
static{
try {
InputStream is = DBCPUtilsReadConfig.class.getClassLoader().getResourceAsStream("dbcpconfig.properties");
//创建Propertis集合
Properties pro=new Properties();
pro.load(is);
//把配置文件传入BasicDataSourceFactory静态方法createDataSource中
dataSourse = BasicDataSourceFactory.createDataSource(pro);
} catch (Exception e) {
throw new RuntimeException("读取配置文件失败");
}
}
//创建获取数据库连接对象的方法
public static Connection getConnection(){
try {
return dataSourse.getConnection();
} catch (SQLException e) {
throw new RuntimeException(e+"连接数据库失败");
}
}
public static void close(ResultSet rs,Statement stat,Connection conn){
if(rs!=null){
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(stat !=null){
try {
stat.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(conn != null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
C3P0连接池
C3P0开源免费的连接池!目前使用它的开源项目有:Spring、Hibernate等。使用第三方工具需要导入jar包,c3p0使用时还需要添加配置文件 c3p0-config.xml
创建C3P0连接池的工具类
连接的规范接口:javax.sql.DataSource接口
接口的实现类对象ComboPooledDataSource
成员位置创建ComboPooledDataSource对象
C3P0内部会自动扫描并解析xml文件,给ComboPooledDataSource设置数据量的4大连接信息
创建一个静态方法返回Connection对象
创建一个静态方法释放资源
publicclass C3P0UtilsReadXML {
privatestatic ComboPooledDataSource dataSource = new ComboPooledDataSource();
//使用静态代码块给ComboPooledDataSource设置4大数据量连接信息
/*static{
try {
dataSource.setDriverClass("com.mysql.jdbc.Driver");
dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/mybase4");
dataSource.setUser("root");
dataSource.setPassword("root");
} catch (Exception e) {
throw new RuntimeException("设置连接信息失败!");
}
}*/
// 创建一个返回ComboPooledDataSource的方法
publicstatic DataSource getDataSource(){
returndataSource;
}
// 创建一个静态方法返回Connection对象
publicstatic Connection getConnection() {
try {
returndataSource.getConnection();
} catch (SQLException e) {
thrownew RuntimeException(e + "获取数据库连接失败");
}
}
// 定义一个释放资源的方法
publicstaticvoid close(ResultSet rs, Statement stat, Connection conn) {
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (stat != null) {
try {
stat.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
使用DBUtils工具类对数据库表进行增删改查
DBUtils工具类作用:简化JDBC的开发(6步)
DBUtils有3个核心类
1.QueryRunner:使用QueryRunner中的方法对数据库进行增删改查
2.DbUtils:提供了大量的释放资源的方法
3.ResultSetHandler接口:提供了处理查询结果集的方法
QueryRunner类
构造方法:
QueryRunner() 空参数构造方法
调用更新和查询方法的时候,需要传入Connection对象
QueryRunner(DataSource ds) 带DataSource数据库连接池的构造方法
调用更新和查询方法的时候QueryRunner会自动从DataSource实现类对象中获取数据库连接对象,使用完毕会自动归还
成员方法:
执行执行增删改的成员方法
int update(Connection conn, String sql, Object... params)用来执行增删改的SQL
int update(String sql, Object... params) 用来执行增删改的SQL
参数:
Connection conn:数据库连接对象
String sql:拼接的sql语句,可以使用?占位符
Object... params:?占位符的实际参数,可以使用Object[]
返回值:
int:执行的有效行数
执行执行查询的成员方法
<T> T query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params)
<T> T query(String sql, ResultSetHandler<T> rsh, Object... params)
参数:
Connection conn:数据库连接对象
String sql:拼接的sql语句,可以使用?占位符
Object... params:?占位符的实际参数,可以使用Object[]
ResultSetHandler<T> rsh:用来存储查询之后的结果集,可以传入ResultSetHandler9种实现类对象
返回值:
<T> T:传入的ResultSetHandler实现类不同,返回的结果集也不同,使用泛型,传入什么结果集,就返回对应的类型
JDBC连接池&DBUtils的更多相关文章
- Junit 注解 类加载器 .动态代理 jdbc 连接池 DButils 事务 Arraylist Linklist hashset 异常 哈希表的数据结构,存储过程 Map Object String Stringbufere File类 文件过滤器_原理分析 flush方法和close方法 序列号冲突问题
Junit 注解 3).其它注意事项: 1).@Test运行的方法,不能有形参: 2).@Test运行的方法,不能有返回值: 3).@Test运行的方法,不能是静态方法: 4).在一个类中,可以同时定 ...
- 【JDBC&Dbutils】JDBC&JDBC连接池&DBUtils使用方法(重要)
-----------------------JDBC---------- 0. db.properties文件 driver=com.mysql.jdbc.Driver url=jdbc: ...
- JDBC连接池&DBUtils使用
使用连接池改造JDBC的工具类: 1.1.1 需求: 传统JDBC的操作,对连接的对象销毁不是特别好.每次创建和销毁连接都是需要花费时间.可以使用连接池优化的程序. * 在程序开始的 ...
- JDBC连接池和DBUtils
本节内容: JDBC连接池 DBUtils 一.JDBC连接池 实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况我们采取连接池技术,来共享连接Conne ...
- 【JAVAWEB学习笔记】10_JDBC连接池&DBUtils
使用连接池改造JDBC的工具类: 1.1.1 需求: 传统JDBC的操作,对连接的对象销毁不是特别好.每次创建和销毁连接都是需要花费时间.可以使用连接池优化的程序. * 在程序开始的 ...
- jdbc连接池&改进dbUtil成C3P0Util
一.jdbc连接池 1.连接池的存在理由 前面介绍的dbUtils工具类虽然实现了一个对jdbc的简单封装.但它依旧采取从驱动管理获取连接 (DriverManager.getConnection ...
- 四大流行的jdbc连接池之C3P0篇
C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSourc ...
- Spring+SpringMVC+MyBatis+easyUI整合优化篇(九)数据层优化-jdbc连接池简述、druid简介
日常啰嗦 终于回到既定轨道上了,这一篇讲讲数据库连接池的相关知识,线程池以后有机会再结合项目单独写篇文章(自己给自己挖坑,不知道什么时候能填上),从这一篇文章开始到本阶段结束的文章都会围绕数据库和da ...
- JDBC连接池-C池3P0连接
JDBC连接池-C3P0连接 c3p0连接池的学习英语好的看英文原版 c3p0 - JDBC3 Connection and Statement Pooling 使用c3p0连接池 三种方 ...
随机推荐
- tomcat------->简单配置
主机名:www.snowing.com 域名:snowing.com http://主机+服务器端口号/path(web应用)/xxx.html 例: http://localhost:8080/it ...
- swift 下storyboard的页面跳转和传值
------------------1. 最简单的方法 拖拽, 这个就不用多解释了吧. 直接拖拽到另一个视图控制器, 选择 show, 就行了. 2. 利用 Segue 方法 (这里主要是 方法1 的 ...
- ASP.NET Identity 2集成到MVC5项目--笔记01
Identiry2是微软推出的Identity的升级版本,较之上一个版本更加易于扩展,总之更好用.如果需要具体细节.网上具体参考Identity2源代码下载 参考文章 在项目中,是不太想直接把这一堆堆 ...
- PHP Version 7.0.13-0ubuntu0.16.04.1 mysql-server-5.7
https://zh.wikipedia.org/wiki/Linux发行版 一个典型的Linux桌面发行版包括一个Linux 内核,来自GNU的工具和库,和附加的软件.文档,还有一个窗口系统,窗口管 ...
- FW:主流RPC框架
主流RPC框架 2015年10月27日 zman RPC 介绍目前在互联网公司比较流行的开源的RPC框架. RPC框架比较 语言 协议 服务治理 社区 机构 Hessian 多语言 he ...
- [LeetCode] 1.Two Sum - Swift
1. Two Sum Given an array of integers, return indices of the two numbers such that they add up to a ...
- 关闭在chrome里使用双指前进后退页面的功能
defaults write com.google.Chrome AppleEnableSwipeNavigateWithScrolls -bool FALSE
- MySQL单列索引和组合索引的区别介绍(转)
原文:http://database.51cto.com/art/201011/233234.htm MySQL单列索引是我们使用MySQL数据库中经常会见到的,MySQL单列索引和组合索引的区别可能 ...
- python 面向对象(进阶篇)转载武沛齐
上一篇<Python 面向对象(初级篇)>文章介绍了面向对象基本知识: 面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类 是一个模板,模板中包装了多个“函数”供使 ...
- 【云安全与同态加密_调研分析(1)】国外云安全标准机构——By Me
在云计算领域,传统的信息安全管理标准如ITIL.ISO/IEC20000.ISO/IEC27001.27002.Cobit等被建议应用于云计算安全管理和控制框架的建立.此外,由于云计算本身区别于传统信 ...