自定义JDBC链接池
上篇简单介绍了jdbc链接数据库;
本篇就说一下自定义连接池以及增删改查的测试:
自定义连接池
自定义链接池的原因
JDBC连接中用到Connection 在每次对数据进行增删查改 都要 开启 、关闭 ,在开发项目中 ,浪费了很大的资源 ,所以我们自己定义了一个连接池,用池来管理Connection,这样可以重复使用Connection,有了池,我们就不用自己来创建Connection,而是通过池来获取Connection对象,当使用完Connection后,调用Connection的close()方法也不会真的关闭Connection,而是把Connection“归还”给池,池也就可以再利用这个Connection对象。
创建自定义连接池的步骤
1 创建连接池实现(数据源),并实现接口javax.sql.DataSource.
2 提供一个集合,用于存放连接,因为移除/添加操作过多,所以选用LinkedList较好
3 为连接池初始化连接
4 程序如果需要连接,调用实现类的getConnection(),本方法将从连接池(容器List)获取连接,为了保证当前连接只是停工给一个线程使用,我们需要将连接先从连接池中移除。
5 当用户使用完连接,释放资源时,不执行close()方法,而是将连接添加到连接池中
自定义连接池的代码:
package com.baidu.database.tools; import java.io.PrintWriter;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.SQLFeatureNotSupportedException;
import java.util.LinkedList;
import java.util.logging.Logger; import javax.sql.DataSource; /**
* 自定义连接池
*
* @author Admin
*
*/
public class MyDatabasePool implements DataSource { /**
* 创建集合存放连接
*/
public LinkedList<Connection> list = new LinkedList<>(); // 使用构造方法初始化连接池
public MyDatabasePool() throws Exception {
// 创建最小连接数个数据库连接对象以备使用
for (int i = 1; i < 21; i++) {
// 将创建好的数据库连接对象添加到Linkedlist集合中
list.add(JdbcUtils.getConnection());
}
} @Override
public void setLogWriter(PrintWriter out) throws SQLException {
// TODO Auto-generated method stub } @Override
public void setLoginTimeout(int seconds) throws SQLException {
// TODO Auto-generated method stub } @Override
public int getLoginTimeout() throws SQLException {
// TODO Auto-generated method stub
return 0;
} @Override
public Logger getParentLogger() throws SQLFeatureNotSupportedException {
// TODO Auto-generated method stub
return null;
} @Override
public <T> T unwrap(Class<T> iface) throws SQLException {
// TODO Auto-generated method stub
return null;
} @Override
public boolean isWrapperFor(Class<?> iface) throws SQLException {
// TODO Auto-generated method stub
return false;
} /**
* 获取链接 通过动态代理(Proxy)实现的数据库连接池的创建连接与归还链接的操作
*/
@Override
public Connection getConnection() throws SQLException {
Connection connection = list.removeLast();
//创建代理对象
Connection proxyConnection = (Connection) Proxy.newProxyInstance(
//类加载器
connection.getClass().getClassLoader(),
//目标接口对象
new Class[] { Connection.class },
//当调用connction对象的时候自动触发事务处理器
new InvocationHandler() {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//判断执行close()就把连接放入连接池
if ("close".equals(method.getName())) {
//连接放入连接池
list.addLast(connection);
return null;
} else {
//调用目标方法对象
return method.invoke(connection, args);
} }
});
return proxyConnection; } @Override
public Connection getConnection(String username, String password) throws SQLException {
// TODO Auto-generated method stub
return null;
} @Override
public PrintWriter getLogWriter() throws SQLException {
// TODO Auto-generated method stub
return null;
} }
JdbcUtils地址
★测试增删改查:
package com.baidu.database.test; import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet; import org.junit.After;
import org.junit.Before;
import org.junit.Test; import com.baidu.database.tools.JdbcUtils;
import com.baidu.database.tools.MyDatabasePool; public class MySouceTest { // 初始化value
static MyDatabasePool database = null;
static Connection connection = null;
static PreparedStatement statement = null;
static ResultSet result = null;
@Before
public void StartDocument() throws Exception {
// 创建自定义数据库对象
database = new MyDatabasePool();
} @After
public void end() throws Exception {
// 关闭链接
JdbcUtils.close(connection, statement, result);
System.out.println("关闭链接");
} @Test
/**
* 测试添加功能
*
* @throws Exception
*/
public void addTest() throws Exception {
// 获取链接
connection = database.getConnection();
// 书写SQL语句
String sql = "insert into test01 values(?,?)";
// 使用prepareStatement对象进行预编译
statement = connection.prepareStatement(sql);
// 设置参数
statement.setInt(1, 1);
statement.setString(2, "张三");
// 获取结果
int result = statement.executeUpdate(); if (result != 0) {
System.out.println("success");
}
} @Test
/**
* 测试删除功能
*
* @throws Exception
*/
public void delTest() throws Exception {
// 获取链接
connection = database.getConnection();
// 书写SQL语句
String sql = "delete from test01 where id=?";
// 使用prepareStatement对象进行预编译
statement = connection.prepareStatement(sql);
// 设置参数
statement.setInt(1, 1);
// 获取结果
int result = statement.executeUpdate(); if (result != 0) {
System.out.println("success");
}
} @Test
public void updateTest() throws Exception {
// 获取链接
connection = database.getConnection();
// 书写SQL语句
String sql = "update test01 set name=? where id=?";
// 使用prepareStatement对象进行预编译
statement = connection.prepareStatement(sql);
// 设置参数
statement.setString(1, "admin");
statement.setInt(2, 1);
// 获取结果
int result = statement.executeUpdate(); if (result != 0) {
System.out.println("success");
}
} @Test
/**
* 测试查询全部
*
* @throws Exception
*/
public void selectTest() throws Exception { // 创建链接
connection = database.getConnection();
if (connection == null) {// 判断是否获取到了链接
return;
}
// 书写SQL
String sql = "select id,name from test01 where id=?";
// 预编译SQL
statement = connection.prepareStatement(sql);
// 设置参数
statement.setInt(1, 1);
// 获取结果集
result = statement.executeQuery(); if (result.next()) {
System.out.println("successful");
} }
}
这就是自定义一个简单的JDBC连接池实现方法,希望能给大家一个参考,也希望大家多多支持我。
自定义JDBC链接池的更多相关文章
- jdbc 链接池的优化
package cn.itcast.jdbc.datasourse; import java.sql.Connection;import java.sql.DriverManager;import j ...
- jdbc 链接池
package cn.itcast.jdbc.datasourse; import java.sql.Connection;import java.sql.DriverManager;import j ...
- java通过代理创建Conncection对象与自定义JDBC连接池
最近学习了一下代理发现,代理其实一个蛮有用的,主要是用在动态的实现接口中的某一个方法而不去继承这个接口所用的一种技巧,首先是自定义的一个连接池 代码如下 import java.lang.reflec ...
- JDBC核心技术(获取数据库链接、数据库事务、数据库链接池)
@ 目录 前言 数据的持久化 Java数据存储技术 JDBC介绍 JDBC体系结构 获取数据库链接 Driver接口 加载注册JDBC驱动 获取数据库链接 数据库链接方式(实例) 方式一:代码中显示出 ...
- JDBC连接池-自定义连接池
JDBC连接池 java JDBC连接中用到Connection 在每次对数据进行增删查改 都要 开启 .关闭 ,在实例开发项目中 ,浪费了很大的资源 ,以下是之前连接JDBC的案例 pack ...
- 自定义一个简单的JDBC连接池
一.什么是JDBC连接池? 在传统的JDBC连接中,每次获得一个Connection连接都需要加载通过一些繁杂的代码去获取,例如以下代码: public static Connection getCo ...
- 诡异的druid链接池链接断开故障经验总结
背景 症状 排查 修复 背景 最近在陆续做机房升级相关工作,配合DBA对产线数据库链接方式做个调整,将原来直接链接读库的地址切换到统一的读负载均衡的代理 haproxy 上,方便机柜和服务器的搬迁. ...
- 【JDBC&Dbutils】JDBC&JDBC连接池&DBUtils使用方法(重要)
-----------------------JDBC---------- 0. db.properties文件 driver=com.mysql.jdbc.Driver url=jdbc: ...
- JDBC连接池(数据源)
自定义连接池:用装饰设计模式将原连接的close方法改造成将连接还回数据源:装饰设计模式:http://www.cnblogs.com/tongxuping/p/6832518.html: 开源数据库 ...
随机推荐
- Xcode 命令行工具 Command Line Tools
xcode命令行工具包是一个小型独立包,可供下载独立于Xcode的和允许您执行命令行开发OS X. 在OS X10.9,就以及没有clt的下载安装包了,需要使用命令在线安装. xcode-select ...
- Redis配置与安装
Redis 是一个非关系型高性能的key-value数据库.在部分场合可以对关系数据库起到很好的补充作用.它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C, ...
- qt程序启动播放动画
qt程序启动播放动画 编辑删除转载 2016-01-20 10:23:11 标签:qt启动动画 1.播放动画 QAxWidget *flash = , ); //QAxWidget使用的是Active ...
- IIS 部署.netcore 500.19错误
错误原因,没有安装 DotNetCore.2.0.5-WindowsHosting.exe 即托管程序,具体可以先检查IIS模块中有没有AspNetCoreModule,有则说明已安装,反正则无
- asp.net core系列 25 EF模型配置(隐藏属性)
一. 隐藏属性概述 隐藏属性也叫影子属性,该属性不是在.net实体类中定义的属性,而是在EFCore模型中为该实体类型定义的属性.这些属性的值和状态完全在变更跟踪器中维护.它有二个功能:(1)当数据库 ...
- Java基础13:反射详解
本节主要介绍Java反射的原理,使用方法以及相关的技术细节,并且介绍了关于Class类,注解等内容. 具体代码在我的GitHub中可以找到 https://github.com/h2pl/MyTech ...
- 采用config方式灵活配置我们的Quarz.net中的Job,Trigger
经常在项目中遇到定时任务的时候,通常第一个想到的是Timer定时器,但是这玩意功能太弱鸡,实际上通常采用的是专业化的第三方调度框架,比如说 Quartz,它具有功能强大和应用的灵活性,我想使用过的人都 ...
- 原型模式 prototype 创建型 设计模式(七)
原型模式 prototype 意图 用原型实例指定需要创建的对象的类型,然后使用复制这个原型对象的方法创建出更多同类型的对象 显然,原型模式就是给出一个对象,然后克隆一个或者更多个对象 小时候看 ...
- 痞子衡嵌入式:常用的数据差错控制技术(3)- 和校验(Checksum)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家讲的是嵌入式里数据差错控制技术-和校验. 在系列前一篇文章里,痞子衡给大家介绍了比较简单的校验法-奇偶校验,该校验法主要是针对byte传输校验而 ...
- [.NET] 《Effective C#》快速笔记(二)- .NET 资源托管
<Effective C#>快速笔记(二)- .NET 资源托管 简介 续 <Effective C#>读书笔记(一)- C# 语言习惯. .NET 中,GC 会帮助我们管理内 ...