上篇简单介绍了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链接池的更多相关文章

  1. jdbc 链接池的优化

    package cn.itcast.jdbc.datasourse; import java.sql.Connection;import java.sql.DriverManager;import j ...

  2. jdbc 链接池

    package cn.itcast.jdbc.datasourse; import java.sql.Connection;import java.sql.DriverManager;import j ...

  3. java通过代理创建Conncection对象与自定义JDBC连接池

    最近学习了一下代理发现,代理其实一个蛮有用的,主要是用在动态的实现接口中的某一个方法而不去继承这个接口所用的一种技巧,首先是自定义的一个连接池 代码如下 import java.lang.reflec ...

  4. JDBC核心技术(获取数据库链接、数据库事务、数据库链接池)

    @ 目录 前言 数据的持久化 Java数据存储技术 JDBC介绍 JDBC体系结构 获取数据库链接 Driver接口 加载注册JDBC驱动 获取数据库链接 数据库链接方式(实例) 方式一:代码中显示出 ...

  5. JDBC连接池-自定义连接池

    JDBC连接池 java JDBC连接中用到Connection   在每次对数据进行增删查改 都要 开启  .关闭  ,在实例开发项目中 ,浪费了很大的资源 ,以下是之前连接JDBC的案例 pack ...

  6. 自定义一个简单的JDBC连接池

    一.什么是JDBC连接池? 在传统的JDBC连接中,每次获得一个Connection连接都需要加载通过一些繁杂的代码去获取,例如以下代码: public static Connection getCo ...

  7. 诡异的druid链接池链接断开故障经验总结

    背景 症状 排查 修复 背景 最近在陆续做机房升级相关工作,配合DBA对产线数据库链接方式做个调整,将原来直接链接读库的地址切换到统一的读负载均衡的代理 haproxy 上,方便机柜和服务器的搬迁. ...

  8. 【JDBC&Dbutils】JDBC&JDBC连接池&DBUtils使用方法(重要)

    -----------------------JDBC---------- 0.      db.properties文件 driver=com.mysql.jdbc.Driver url=jdbc: ...

  9. JDBC连接池(数据源)

    自定义连接池:用装饰设计模式将原连接的close方法改造成将连接还回数据源:装饰设计模式:http://www.cnblogs.com/tongxuping/p/6832518.html: 开源数据库 ...

随机推荐

  1. 前端笔记之HTML5&CSS3(中)选择器&伪类伪元素&CSS3效果&渐变背景&过渡

    一.CSS3选择器 CSS3是CSS的第三代版本,新增了很多功能,例如:强大的选择器.盒模型.圆角.渐变.动画.2D/3D转换.文字特效等. CSS3和HTML5没有任何关系!HTML5骨架中,可以用 ...

  2. linux(centos)搭建.net core 运行环境

     总的来说,非常简单,我记录一下: 1.打开https://www.microsoft.com/net/download?initial-os=linux 这里"Instal .NET C ...

  3. JavaWeb中使用JSON

    前言: 最近也是期末了,有好多好多文档和实验报告要交,所以都没啥时间写文,这段时间清闲了,来补一下之前学习时遗漏的一些知识树,话说就没人吐槽这个JSON图标好丑吗? 什么是JSON JSON 指的是 ...

  4. leetcode — gas-station

    /** * Source : https://oj.leetcode.com/problems/gas-station/ * * There are N gas stations along a ci ...

  5. RDIFramework.NET ━ .NET快速信息化系统开发框架 V3.2->新增模块管理界面导出功能(可按条件导出)

    导出功能在很多应用场景中都需要,RDIFramework.NET V3.2版本在模块管理界面新增了导出功能,方便管理员对所有配置的模块进行管理. 一.Web版模块管理导出功能 Web版本的模块导出功能 ...

  6. 关于微信小程序textarea层级过高问题解决

    一.前言 相信做过微信小程序开发的人应该都碰到过这个问题,因为这个需求实在太常见了 由于textarea是属于原生组件,层级最高,不管在页面中我们设置z-index值多少都会被textarea组件遮挡 ...

  7. 全网Star最多(近20k)的Spring Boot开源教程 2019 年要继续更新了!

    从2016年1月开始写博客,默默地更新<Spring Boot系列教程>,从无人问津到千万访问,作为一个独立站点(http://blog.didispace.com),相信只有那些跟我一样 ...

  8. Java开发笔记(二十九)大整数BigInteger

    早期的编程语言为了节约计算机的内存,给数字变量定义了各种存储规格的数值类型,比如字节型byte只占用一个字节大小,短整型short占用两个字节大小,整型int占用四个字节大小,长整型long占用八个字 ...

  9. 永不重复的id生成器

    目录 (1)需要导入的包 (2)IdGenerator类 (3)使用举例 (1)需要导入的包 主要用在格式化日FastDateFormat.getInstance("yyyyMMddHHmm ...

  10. 【Docker】基础学习及在.Net Core应用

    一.Docker基础 Docker 是一个开源的应用容器引擎,基于 Go 语言 Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上 ...