上篇简单介绍了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. Apache生产配置

    httpd.conf # # This is the main Apache HTTP server configuration file. It contains the # configurati ...

  2. 个人玩耍VUE..我的点点滴滴,今天很冷,2度!!!

    谢谢博客园,可以记录我的点点滴滴.!!这个小案例的效果图 其中,这篇还是上一篇博客的序章,我们直接看下更新的代码. Cart.Vue <template> <div class=&q ...

  3. 【单例模式】java实现

    概述:确保一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 关键点: 构造函数不对外开放,一般为private. 通过一个静态方法或者枚举返回单例类对象. 确保单例类的对象有且只有一个,尤 ...

  4. 为VIP解决问题时写的源码

    平时为学生们解决问题时,建立的项目源代码,方便大家学习与讨论. 开源DEMO列表 1. https://github.com/bfyxzls/student_orderBy 2. https://gi ...

  5. 【Java基础】【03运算符&if语句】

    03.01_Java语言基础(逻辑运算符的基本用法)(掌握) A:逻辑运算符有哪些 &,|,^,! &&,|| B:案例演示 逻辑运算符的基本用法 注意事项: a:逻辑运算符一 ...

  6. man帮助文档打印

    这里不讨论大家都知道的man重定向的一般常用方法(col处理方法)$ man find | col -b > man_fine.txt [跟着我的思路走]假如您像我一样,直接使用如下命令导出fi ...

  7. PE知识复习之PE的两种状态

    PE知识复习之PE的两种状态 一丶熟悉PE的整体结构 从下面依次网上看.可以得出PE结构 其中DOS头有DOS头结构 也就是 IMAGE_DOS_HEADER 关于结构体的各项属性.前边已经写过了.本 ...

  8. Linux下安装Tomcat启动报错

    一.报以下错误: Using CATALINA_BASE:   /home/apache-tomcat-7.0.72Using CATALINA_HOME:   /home/apache-tomcat ...

  9. 大数据利器Hive

    序言:在大数据领域存在一个现象,那就是组件繁多,粗略估计一下轻松超过20种.如果你是初学者,瞬间就会蒙圈,不知道力往哪里使.那么,为什么会出现这种现象呢?在本文的开头笔者就简单的阐述一下这种现象出现的 ...

  10. 基于.Net进行前端开发的技术栈发展路线(三)

    前言 上一篇<我的技能树二>文章分享了我的技能中的前端技能和Java技能,今天继续跟大家分享的就是后端技能了. 我的技能树 我当前的技能树: 其中,标注为黄色旗帜的是基本掌握,标注为红色旗 ...