DBUtils和连接池

今日内容介绍

DBUtils

连接池

第1章 DBUtils

如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache commons组件一个成员:DBUtils。

DBUtils就是JDBC的简化开发工具包。需要项目导入commons-dbutils-1.6.jar才能够正常使用DBUtils工具。

1.1 概述

DBUtils是java编程中的数据库操作实用工具,小巧简单实用。

DBUtils封装了对JDBC的操作,简化了JDBC操作,可以少写代码。

Dbutils三个核心功能介绍

l QueryRunner中提供对sql语句操作的API.

l ResultSetHandler接口,用于定义select操作后,怎样封装结果集.

l DbUtils类,它就是一个工具类,定义了关闭资源与事务处理的方法

1.2 QueryRunner核心类

l update(Connection conn, String sql, Object... params) ,用来完成表数据的增加、删除、更新操作

l query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) ,用来完成表数据的查询操作

1.3 QueryRunner实现添加、更新、删除操作

l update(Connection conn, String sql, Object... params) ,用来完成表数据的增加、删除、更新操作

1.3.1 添加

public void insert(){

try {

//获取一个用来执行SQL语句的对象   QueryRunner

QueryRunner qr = new QueryRunner();

String sql = "INSERT INTO zhangwu(name,money,parent) VALUES(?,?,?)";

Object[] params = {"股票收入", 5500, "收入"};

Connection conn = JDBCUtils.getConnection();

int line = qr.update(conn,sql,params);// 用来完成表数据的增加、删除、更新操作

//结果集处理

System.out.println("line = " + line);

} catch (SQLException e) {

throw new RuntimeException(e);

}

}

1.3.2 更新

public void update(){

try {

//创建一个QueryRunner对象,用来完成SQL语句的执行

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "UPDATE zhangwu SET money = money+1000 WHERE name=?";

Object[] params = {"股票收入"};

Connection conn = JDBCUtils.getConnection();

int line = qr.update(conn, sql, params);

//结果集的处理

System.out.println("line="+line);

} catch (SQLException e) {

throw new RuntimeException(e);

}

}

1.3.3 删除

public void delete(){

try {

//创建一个QueryRunner对象,用来完成SQL语句的执行

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "DELETE FROM zhangwu WHERE name = ?";

Object[] params = {"股票收入"};

Connection conn = JDBCUtils.getConnection();

int line = qr.update(conn, sql, params);

//结果集的处理

System.out.println("line="+line);

} catch (SQLException e) {

throw new RuntimeException(e);

}

}

1.4 QueryRunner实现查询操作

l query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) ,用来完成表数据的查询操作

1.4.1 ResultSetHandler结果集处理类

ArrayHandler

将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值

ArrayListHandler

将结果集中的每一条记录都封装到一个Object[]数组中,将这些数组在封装到List集合中。

BeanHandler

将结果集中第一条记录封装到一个指定的javaBean中。

BeanListHandler

将结果集中每一条记录封装到指定的javaBean中,将这些javaBean在封装到List集合中

ColumnListHandler

将结果集中指定的列的字段值,封装到一个List集合中

ScalarHandler

它是用于单数据。例如select count(*) from 表操作。

MapHandler

将结果集第一行封装到Map集合中,Key 列名, Value 该列数据

MapListHandler

将结果集第一行封装到Map集合中,Key 列名, Value 该列数据,Map集合存储到List集合

1.4.2 JavaBean

JavaBean就是一个类,在开发中常用封装数据。具有如下特性

  1. 需要实现接口:java.io.Serializable ,通常实现接口这步骤省略了,不会影响程序。
  2. 提供私有字段:private 类型 字段名;
  3. 提供getter/setter方法:
  4. 提供无参构造

/*

* 账务类

*/

public class ZhangWu {

private int id;

private String name;

private double money;

private String parent;

public ZhangWu() {

super();

}

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public double getMoney() {

return money;

}

public void setMoney(double money) {

this.money = money;

}

public String getParent() {

return parent;

}

public void setParent(String parent) {

this.parent = parent;

}

@Override

public String toString() { //该方法可以省略

return "ZhangWu [id=" + id + ", name=" + name + ", money=" + money + ", parent=" + parent + "]";

}

}

1.4.3 ArrayHandler与ArrayListHandler查询

l ArrayHandler:将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值

public class ArrayHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM zhangwu";

Object[] params = {};

Connection conn = JDBCUtils.getConnection();

Object[] objArray = qr.query(conn, sql, new ArrayHandler(), params);

//结果集的处理

System.out.println( Arrays.toString(objArray) );

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

l ArrayListHandler:将结果集中的每一条记录都封装到一个Object[]数组中,将这些数组在封装到List集合中。

public class ArrayListHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM zhangwu WHERE money>?";

Object[] params = {2000};

Connection conn = JDBCUtils.getConnection();

List<Object[]> list = qr.query(conn, sql, new ArrayListHandler(), params);

//结果集的处理

for (Object[] objArray : list) {

System.out.println(  Arrays.toString(objArray) );

}

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

1.4.4 BeanHandler与BeanListHandler查询

l BeanHandler :将结果集中第一条记录封装到一个指定的javaBean中。

public class BeanHandlerDemo {

@Test

public void method(){

try{

//获取QueryRunner

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM zhangwu WHERE id=?";

Object[] params = {1};

Connection conn = JDBCUtils.getConnection();

ZhangWu zw = qr.query(conn, sql, new BeanHandler<ZhangWu>(ZhangWu.class), params);

//结果集处理

System.out.println(zw);

conn.close();

} catch(SQLException e){

throw new RuntimeException(e);

}

}

}

l BeanListHandler :将结果集中每一条记录封装到指定的javaBean中,将这些javaBean在封装到List集合中

public class BeanListHandlerDemo {

@Test

public void method(){

try{

//获取QueryRunner

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT * FROM zhangwu WHERE money>?";

Object[] params = {2000};

Connection conn = JDBCUtils.getConnection();

List<ZhangWu> list = qr.query(conn, sql, new BeanListHandler<ZhangWu>(ZhangWu.class), params);

//结果集处理

for (ZhangWu zw : list) {

System.out.println(zw);

}

conn.close();

} catch(SQLException e){

throw new RuntimeException(e);

}

}

}

1.4.5 ColumnListHandler与ScalarHandler查询

l ColumnListHandler:将结果集中指定的列的字段值,封装到一个List集合中

public class ColumnListHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT name FROM zhangwu WHERE money>?";

Object[] params = {2000};

Connection conn = JDBCUtils.getConnection();

List<String> list = qr.query(conn, sql, new ColumnListHandler<String>(), params);

//结果集的处理

for (String str : list) {

System.out.println(str);

}

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

l ScalarHandler:它是用于单数据。例如select count(*) from 表操作。

public class ScalarHandlerDemo {

@Test

public void method(){

try {

//获取QueryRunner对象

QueryRunner qr = new QueryRunner();

//执行SQL语句

String sql = "SELECT MAX(money) FROM zhangwu";

Object[] params = {};

Connection conn = JDBCUtils.getConnection();

Double max = qr.query(conn, sql, new ScalarHandler<Double>(), params);

//结果集的处理

System.out.println("max=" + max);

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

第2章 连接池

实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况我们采用连接池技术,来共享连接Connection。这样我们就不需要每次都创建连接、释放连接了,这些操作都交给了连接池

2.1 连接池概述

l 概念

用池来管理Connection,这样可以重复使用Connection。有了池,所以我们就不用自己来创建Connection,而是通过池来获取Connection对象。当使用完Connection后,调用Connection的close()方法也不会真的关闭Connection,而是把Connection“归还”给池。池就可以再利用这个Connection对象了。

l 规范

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

常见的连接池:DBCP、C3P0。

接下来,我们就详细的学习一下DBCP连接池。C3P0连接池我们在就业班学习。

2.2 DBCP连接池  

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

2.2.1 导入jar包

2.2.2 编写工具类

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

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

public class JDBCUtils {

public static final String DRIVER = "com.mysql.jdbc.Driver";

public static final String URL = "jdbc:mysql://localhost:3306/daydb";

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;

}

}

2.2.3 工具类的使用

l 测试类

/*

* 演示使用DBUtils工具  完成数据库表的增加操作

*/

public class Demo {

// 插入功能

@Test

public void insert(){

try {

//获取一个用来执行SQL语句的对象   QueryRunner

QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());

String sql = "INSERT INTO zhangwu(name,money,parent) VALUES(?,?,?)";

Object[] params = {"股票收入", 5500, "收入"};

int line = qr.update(sql,params);

//结果集处理

System.out.println("line = " + line);

} catch (SQLException e) {

throw new RuntimeException(e);

}

}

//删除功能

@Test

public void delete(){

try {

//创建一个QueryRunner对象,用来完成SQL语句的执行

QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());

//执行SQL语句

String sql = "DELETE FROM zhangwu WHERE name = ?";

Object[] params = {"股票收入"};

int line = qr.update(sql, params);

//结果集的处理

System.out.println("line="+line);

} catch (SQLException e) {

throw new RuntimeException(e);

}

}

//更新功能

@Test

public void update(){

try {

//创建一个QueryRunner对象,用来完成SQL语句的执行

QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());

//执行SQL语句

String sql = "UPDATE zhangwu SET money = money+1000 WHERE name=?";

Object[] params = {"股票收入"};

int line = qr.update(sql, params);

//结果集的处理

System.out.println("line="+line);

} catch (SQLException e) {

throw new RuntimeException(e);

}

}

//查询功能,将结果集中第一条记录封装到一个指定的javaBean中。

@Test

public void search(){

try{

//获取QueryRunner

QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());

//执行SQL语句

String sql = "SELECT * FROM zhangwu";

Object[] params = {};

Product p = qr.query(sql, new BeanHandler<Product>(Product.class), params);

//结果集处理

System.out.println(p);

} catch(SQLException e){

throw new RuntimeException(e);

}

}

}

2.2.4 常见配置项

分类

属性

描述

必须项

driverClassName

数据库驱动名称

url

数据库的地址

username

用户名

password

密码

基本项(扩展)

maxActive

最大连接数量

minIdle

最小空闲连接

maxIdle

最大空闲连接

initialSize

初始化连接

参考文档:http://commons.apache.org/proper/commons-dbcp/configuration.html

第3章 总结

l DBUtils工具

l 作用:简化JDBC的操作

l 常用类与方法

l QueryRunner 用来执行SQL语句对象

l update(Connection conn, String sql, Object… params) 插入表记录、更新表记录、删除表记录

l query(Connection conn, String sql, ResultSetHandler handler, Object… params) 查询表记录

l ResultSetHandler 处理结果集的对象

ArrayHandler

将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值

ArrayListHandler

将结果集中的每一条记录都封装到一个Object[]数组中,将这些数组在封装到List集合中。

BeanHandler

将结果集中第一条记录封装到一个指定的javaBean中。

BeanListHandler

将结果集中每一条记录封装到指定的javaBean中,将这些javaBean在封装到List集合中

ColumnListHandler

将结果集中指定的列的字段值,封装到一个List集合中

ScalarHandler

它是用于单数据。例如select count(*) from 表操作。

MapHandler

将结果集第一行封装到Map集合中,Key 列名, Value 该列数据

MapListHandler

将结果集第一行封装到Map集合中,Key 列名, Value 该列数据,Map集合存储到List集合

l DBCP连接池

l 作用:自身维护了多个Connection连接对象维护

l BasicDataSource类  是  DataSource接口的实现类

l DataSource接口,它是java与每种数据库连接池 连接的规范标准

l DBCP连接池常见的配置

必须项

driverClassName

数据库驱动名称

url

数据库的地址

username

用户名

password

密码

基本项

maxActive

最大连接数量

initialSize

连接池中初始化多少个Connection连接对象

扩展项

maxWait

超时等待时间以毫秒为单位 1000等于1秒

数据库(DBUtils)的更多相关文章

  1. 数据库——DBUtils和连接池

    第一章 DBUtils如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache commons组件一个成员:DBUtils.DBUtils就是JDBC的简 ...

  2. 数据库DBUtils基本使用

    Apache-DBUtils简介 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,使用dbutils能极大简化jdbc编码的工作量,同 ...

  3. 数据库dbutils

    common-dbutils.jarQueryRunnerupdate方法:* int update(String sql, Object... params) -->  可执行增.删.改语句* ...

  4. OSChina底层数据库操作的类(QueryHelper)源代码

    OSChina 使用的是 dbutils 这个JDBC的封装类库来进行数据库操作. 而 QueryHelper 则是在 dbutils 的基础上进行一级简单的封装,提供一些经常使用的数据库操作方法和对 ...

  5. 7.数据库、Contentobserver

    群组页是程序内部维护的一个数据库,其中一张表groups,用于存放创建的群组,还有一张表thread_group,用于关联群组和系统短信数据库中的会话. 数据库应该这样设计 MySqliteHelpe ...

  6. Xutils3的使用

    Xutils是前两年很火的一个三方库(githup地址),是一个工具类,分为4个模块:DbUtils.HttpUtils.ViewUtils. BitmapUtils,还有一个非常使用功能就是LogU ...

  7. Java爬取51job保存到MySQL并进行分析

    大二下实训课结业作业,想着就爬个工作信息,原本是要用python的,后面想想就用java试试看, java就自学了一个月左右,想要锻炼一下自己面向对象的思想等等的, 然后网上转了一圈,拉钩什么的是动态 ...

  8. Android后台数据接口交互实现注册功能

    首先,在ecplise里面新建一个叫做TestServices的web工程.在WebContent--WEB-INF--libs文件夹下导入两个jar包:mysql-connector-java-6. ...

  9. JSP应用开发 -------- 电纸书(未完待续)

    http://www.educity.cn/jiaocheng/j9415.html JSP程序员常用的技术   第1章 JSP及其相关技术导航 [本章专家知识导学] JSP是一种编程语言,也是一种动 ...

  10. 使用ThreadLocal、Apache的dbutils的QueryRunner和dbcp2数据库连接池的BasicDataSource封装操作数据库工具

    package hjp.smart4j.framework.helper; import hjp.smart4j.framework.util.CollectionUtil; import hjp.s ...

随机推荐

  1. spring+jax 出现java.io.Serializable is an interface, and JAXB can't handle interfaces

    spring+jax 出现java.io.Serializable is an interface, and JAXB can't handle interfaces 原因是我的webservice方 ...

  2. xgene:疾病相关基因,耳聋,彩色,老年痴呆,帕金森

    神经元的传递:一个下游神经元,它接受其上游神经元的各个突触传过来的信号,然而,每个突触对该下游神经元的激活权重是不同的. 从神经网络的本质上说,当人连续.多次遭受失败的时候,大脑内就会释放大量的抑制性 ...

  3. .Net开发中的@ 和 using 使用技巧

    一.@符号的妙用 1.可以作为保留关键字的标识符 C#规范当中,不允许使用保留关键字(class.bool等)当作普通的标识符来命名,这时候@符号作用就体现 出来了,可以通过@符号前缀把这些保留关键字 ...

  4. JavaScript高级程序设计学习笔记--面向对象的程序设计(二)-- 继承

    相关文章: 面向对象的程序设计(一) — 创建对象 http://www.cnblogs.com/blackwood/archive/2013/04/24/3039523.html 继承 继承是OO语 ...

  5. Mac效率工具推荐

    1.Homebrew 命令行安装神器 https://brew.sh/index_zh-cn.html 2.Alfred 类似spotlight,功能更强大 https://www.alfredapp ...

  6. 递归实现从n个数中选r个数的组合数

    #include <stdio.h> #include <stdlib.h> ], count; void comb(int m, int k) { int i, j; for ...

  7. [poj 1837] Balance dp

    Description Gigel has a strange "balance" and he wants to poise it. Actually, the device i ...

  8. Mac安装pyenv及pyenv的使用

    Mac系统自带的Python是2.7.10,自己需要Python 3.x,此时需要在系统中安装多个Python,但又不能影响系统自带的Python,即需要实现Python的多版本共存,pyenv就是这 ...

  9. js常见问题之为什么点击弹出的i总是最后一个

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. redis使用方法

    redis缓存服务器笔记 redis是一个高性能的key-value存储系统,能够作为缓存框架和队列 但是由于他是一个内存内存系统,这些数据还是要存储到数据库中的 作为缓存框架: create/upd ...