1、连接池概述

  (1)用池来管理Connection,这样可以重复使用Connection;

  (2)有了池,所以我们就不用自己来创建Connection,而是通过池来获取Connection对象;

  (3)当使用完Connection后,调用Connection的close()方法也不会真的关闭Connection,而是把Connection“归还”给池。池就可以再利用这个Connection对象了;

  (4)Java为数据库连接池提供了公共的接口:javax.sql.DataSource,各个厂商需要让自己的连接池实现这个接口。这样应用程序可以方便的切换不同厂商的连接池;

  (5)常见的连接池:DBCP、C3P0。

2、DBCP连接池

  (1)DBCP也是一个开源的连接池,是Apache Common成员之一,在企业开发中也比较常见,tomcat内置的连接池;

  (2)下载并导入commons-dbcp-1.4.jar和commons-pool-1.5.6.jar包,下载链接commons-dbcp-1.4.jar和commons-pool-1.5.6.jar 密码:q81g ;

  (3)编写工具类

    ①连接数据库表的工具类, 采用DBCP连接池的方式来完成,Java中提供了一个连接池的规则接口:

    DataSource : 它是java中提供的连接池,作为 DriverManager 工具的替代项。在DBCP包中提供了DataSource接口的实现类,我们要用的具体的连接池 BasicDataSource类。

 import javax.sql.DataSource;

 import org.apache.commons.dbcp.BasicDataSource;

 public class JDBCUtils {
public static final String DRIVER = "com.mysql.jdbc.Driver";
public static final String URL = "jdbc:mysql://localhost:3306/mybase";
public static final String USERNAME = "root";
public static final String PASSWORD = "root";
/*
* 创建连接池BasicDataSource
*/
public static BasicDataSource dataSource = new BasicDataSource();
// 静态代码块
static {
// 对连接池对象 进行基本的配置
dataSource.setDriverClassName(DRIVER); // 这是要连接的数据库的驱动
dataSource.setUrl(URL); // 指定要连接的数据库地址
dataSource.setUsername(USERNAME); // 指定要连接数据的用户名
dataSource.setPassword(PASSWORD); // 指定要连接数据的密码
} /*
* 返回连接池对象
*/
public static DataSource getDataSource() {
return dataSource;
}
}

  (4)增

  初始数据:

  

 import java.sql.SQLException;

 import org.apache.commons.dbutils.QueryRunner; import org.junit.Test;

 /*
* 演示使用DBUtils工具 完成数据库表的增删改查
*/
public class Demo {
// 插入功能
@Test
public void insert() {
try {
// 获取一个用来执行SQL语句的对象 QueryRunner
QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
String sql = "INSERT INTO Sort(sname) VALUES(?)";
Object[] params = { "遥控器" };
int line = qr.update(sql, params);
// 结果集处理
System.out.println("line = " + line); } catch (SQLException e) {
throw new RuntimeException(e);
}
} }

  运行结果:

  

  (5)删

 import java.sql.SQLException;

 import org.apache.commons.dbutils.QueryRunner;
import org.junit.Test; /*
* 演示使用DBUtils工具 完成数据库表的增删改查
*/
public class Demo {
// 删除功能
@Test
public void delete() {
try {
// 创建一个QueryRunner对象,用来完成SQL语句的执行
QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
// 执行SQL语句
String sql = "DELETE FROM Sort WHERE sid = ?";
Object[] params = { 7 };
int line = qr.update(sql, params);
// 结果集的处理
System.out.println("line=" + line); } catch (SQLException e) {
throw new RuntimeException(e);
}
} }

  运行结果:
  

  (6)改

 import java.sql.SQLException;

 import org.apache.commons.dbutils.QueryRunner;
import org.junit.Test; /*
* 演示使用DBUtils工具 完成数据库表的增删改查
*/
public class Demo {
// 更新功能
@Test
public void update() {
try {
// 创建一个QueryRunner对象,用来完成SQL语句的执行
QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
// 执行SQL语句
String sql = "UPDATE Sort SET sid = sid+2 WHERE sname=?";
Object[] params = { "遥控器" };
int line = qr.update(sql, params);
// 结果集的处理
System.out.println("line=" + line); } catch (SQLException e) {
throw new RuntimeException(e);
}
} }

  运行结果:

  

  (7)查

 import java.sql.SQLException;

 import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.junit.Test; /*
* 演示使用DBUtils工具 完成数据库表的增删改查
*/
public class Demo {
// 查询功能,将结果集中第一条记录封装到一个指定的javaBean中。
@Test
public void search() {
try {
// 获取QueryRunner
QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
// 执行SQL语句
String sql = "SELECT * FROM sort";
Object[] params = {};
Sort p = qr.query(sql, new BeanHandler<Sort>(Sort.class), params);
// 结果集处理
System.out.println(p); } catch (SQLException e) {
throw new RuntimeException(e);
}
} }

  运行结果:

  

  (8)常见配置项

  

  参考文档链接:参考文档

03016_DBCP连接池的更多相关文章

  1. 连接SQLServer时,因启用连接池导致孤立事务的原因分析和解决办法

    本文出处:http://www.cnblogs.com/wy123/p/6110349.html 之前遇到过这么一种情况: 连接数据库的部分Session会出现不定时的阻塞,这种阻塞时长时短,有时候持 ...

  2. C3p0连接池配置

    在Java开发中,使用JDBC操作数据库的四个步骤如下:   ①加载数据库驱动程序(Class.forName("数据库驱动类");)   ②连接数据库(Connection co ...

  3. Java第三方数据库连接池库-DBCP-C3P0-Tomcat内置连接池

    连接池原理 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接池 ...

  4. common-pool2 学习:thrift连接池的另一种实现

    对象池是一种很实用的技术,经典的例子就是数据库连接池.去年曾经从零开始写过一个thrift客户端连接池.如果不想重造轮子,可以直接在apache开源项目commons-pool的基础上开发. 步骤: ...

  5. druid连接池获取不到连接的一种情况

    数据源一开始配置: jdbc.initialSize=1jdbc.minIdle=1jdbc.maxActive=5 程序运行一段时间后,执行查询抛如下异常: exception=org.mybati ...

  6. C3P0连接池配置和实现详解

    一.配置 <c3p0-config> <default-config> <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数.Default: 3 --> ...

  7. hibernate+mysql的连接池配置

    1:连接池的必知概念    首先,我们还是老套的讲讲连接池的基本概念,概念理解清楚了,我们也知道后面是怎么回事了. 以前我们程序连接数据库的时候,每一次连接数据库都要一个连接,用完后再释放.如果频繁的 ...

  8. 连接池的实现 redis例子

    # -*- encoding:utf-8 -*- # import pymysql # # conn = pymysql.connect(host="127.0.0.1", por ...

  9. DBCP连接池配置示例

    <bean id="dataSourceOracle2" class="org.apache.commons.dbcp.BasicDataSource" ...

随机推荐

  1. STM8S汇编代码分析

    转载:http://blog.csdn.net/u010093140/article/details/50021897使用STVD建立完汇编工程项目之后(具本建立方法可以看我的另一篇博文http:// ...

  2. SpringBoot学习笔记(10)-----SpringBoot中使用Redis/Mongodb和缓存Ehcache缓存和redis缓存

    1. 使用Redis 在使用redis之前,首先要保证安装或有redis的服务器,接下就是引入redis依赖. pom.xml文件如下 <dependency> <groupId&g ...

  3. Node_进阶_6

    Node进阶第六天 一.复习 cookie是在res中设置,req中读取的.第一次的访问没有cookie. cookie的存储大小有限,kv对儿.对用户可见,用户可以禁用.清除cookie.可以被篡改 ...

  4. Spring boot配置404、500页面

    Spring boot 配置404页面很简单,如果你访问的url没有找到就会出现spring boot 提示的页面,很明显Spring boot不用配置就可以显示404页面了. 在template下创 ...

  5. WebSocket 前端封装

    $.extend({ socketWeb:function (opt) { if("WebSocket" in window){ var setting=$.extend({ ur ...

  6. POJ-1113 Wall 计算几何 求凸包

    题目链接:https://cn.vjudge.net/problem/POJ-1113 题意 给一些点,求一个能够包围所有点且每个点到边界的距离不下于L的周长最小图形的周长 思路 求得凸包的周长,再加 ...

  7. Valgrind的安装及简单使用

    1.获取源码 wget http://www.valgrind.org/downloads/valgrind-3.14.0.tar.bz2 2.解压缩 tar -jxvf valgrind-3.14. ...

  8. [LeetCode] 155. minStack 设计最小栈

    注意:getMin()时间复杂度为O(1) 最原始的方法: class MinStack(object): def __init__(self): """ initial ...

  9. SWT自定义选项卡CTabFolder

    SWT自定义选项卡CTabFolder 学习了:http://blog.csdn.net/dreajay/article/details/17391731 package com.swt; impor ...

  10. 【通信框架】Google的开源通信框架protobuf概述

    在阅读的过程中有不论什么问题,欢迎一起交流 邮箱:1494713801@qq.com    QQ:1494713801 一.作用 protobuf(Protocol Buffers)是Google内部 ...