JDBC使用DBUtils
1.commons-dbutils
commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用dbutils能极大简化jdbc编码的工作量,同时也不会影响程序的性能。因此dbutils成为很多不喜欢hibernate的公司的首选。
commons-dbutilsAPI包括:
- org.apache.commons.dbutils.QueryRunner
- org.apache.commons.dbutils.ResultSetHandler
工具类
- org.apache.commons.dbutils.DbUtils
2.QueryRunner类
该类简单化了SQL查询,它与ResultSetHandler组合在一起使用可以完成大部分的数据库操作,能够大大减少编码量。
QueryRunner类提供了两个构造方法:
- 默认的构造方法;
- 需要一个 javax.sql.DataSource 来作参数的构造方法。
QueryRunner类的主要方法:

执行一个不需要置换参数的查询操作。

执行一个查询操作,在这个查询中,对象数组中的每个元素值被用来作为查询语句的置换参数

用来执行一个更新(插入、更新或删除)操作。

用来执行一个不需要置换参数的更新操作。
2.1 使用DBUtils进行更新操作,更新操作可用于insert,update,delete.
public void testQueryRunnerUpdate() {
QueryRunner queryRunner=new QueryRunner();
Connection connection=null;
String sql="DELETE FROM USERS WHERE ID IN (?,?)";
try{
connection=JDBCTools.getConnection();
queryRunner.update(connection,sql,1,2);
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCTools.release(null, null, connection);
}
}
数据库连接和释放工具类 JDBCTools.java
//获取数据库的连接
@Test
public static Connection getConnection() throws Exception{
String driverClass=null;
String jdbcUrl=null;
String user=null;
String password=null; InputStream in=JDBCTools.class.getResourceAsStream("/jdbc.properties");
Properties properties=new Properties();
properties.load(in); driverClass=properties.getProperty("driver");
jdbcUrl=properties.getProperty("jdbcUrl");
user=properties.getProperty("user");
password=properties.getProperty("password"); Class.forName(driverClass);
Connection connection=DriverManager.getConnection(jdbcUrl,user,password);
return connection; }
@Test
public void testGetConnection() throws Exception{
getConnection(); }
//数据库释放
public static void release(ResultSet resultset,Statement statement,Connection connection){
if(statement!=null){
try {
statement.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(connection!=null){
try {
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(resultset!=null){
try {
resultset.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
3.使用DBUtils进行查询操作
@Test
public void testQuery(){
Connection connection=null;
try{
connection=JDBCTools.getConnection();
String sql="SELECT id,name,email,birth FROM CUSTOMER";
Object obj=queryRunner.query(connection, sql, new MyResultSetHandler());
System.out.println(obj);
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCTools.release(null, null, connection);
}
} //QueryRunner的返回值取决于ResultSetHandler的返回值
QueryRunner queryRunner=new QueryRunner();
class MyResultSetHandler implements ResultSetHandler{
@Override
public Object handle(ResultSet resultset) throws SQLException {
List<Customer> customers=new ArrayList<Customer>();
while(resultset.next()){
Integer id=resultset.getInt(1);
String name=resultset.getString(2);
String email=resultset.getString(3);
Date date=resultset.getDate(4);
Customer customer=new Customer(id,name,email,date);
customers.add(customer);
}
return customers;
}
}
4.ResultSetHandler接口的实现类
4.1 BeanHandler
把结果集的第一条记录转为创建BeanHandler对象时传入的Class参数对应的对象。
示例代码:
public void testBeanHandler() {
Connection connection=null;
try{
connection=JDBCTools.getConnection();
String sql="SELECT ID,NAME,EMAIL,BIRTH FROM CUSTOMER WHERE ID>=?";
Customer customer=(Customer) queryRunner.query(connection,sql,new BeanHandler(Customer.class),2);
System.out.println(customer);
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCTools.release(null, null, connection);
}
}
运行结果返回:
Customer [id=2, name=Winda, email=3455345466@163.com, birth=1995-02-14]
4.2 BeanListHandler
将结果集中的每一条数据都封装到一个对应的JavaBean实例中,存放到List里。
public void testBeanListHandler(){
Connection connection=null;
try{
connection=JDBCTools.getConnection();
String sql="SELECT ID,NAME,EMAIL,BIRTH FROM CUSTOMER";
List<Customer> customers=(List<Customer>) queryRunner.query(connection,sql,new BeanListHandler(Customer.class));
System.out.println(customers);
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCTools.release(null, null, connection);
}
}
返回结果为:
[Customer [id=1, name=Tom, email=231233134@163.com, birth=1983-09-11], Customer [id=2, name=Winda, email=3455345466@163.com, birth=1995-02-14], Customer [id=3, name=A, email=5534565656@163.com, birth=1995-06-23], Customer [id=4, name=B, email=9444532232@163.com, birth=1992-03-11], Customer [id=5, name=C, email=4234412132@163.com, birth=1996-09-14], Customer [id=6, name=D, email=5634645645@163.com, birth=1990-09-19]]
4.3 MapHandler
返回SQL对应的第一条记录对应的Map对象。键对应列名,值对应列的值。
示例代码:
public void testMapHandler(){
Connection connection=null;
try{
connection=JDBCTools.getConnection();
String sql="SELECT ID,NAME,EMAIL,BIRTH FROM CUSTOMER";
Map<String,Object> result= queryRunner.query(connection,sql,new MapHandler());
System.out.println(result);
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCTools.release(null, null, connection);
}
}
返回结果:
{ID=1, BIRTH=1983-09-11, EMAIL=231233134@163.com, NAME=Tom}
4.4 MapListHandler
将结果集中的每一行数据都封装到一个Map里,然后再存放到List。
public void testMapListHandler(){
Connection connection=null;
try{
connection=JDBCTools.getConnection();
String sql="SELECT ID,NAME,EMAIL,BIRTH FROM CUSTOMER";
List<Map<String,Object>> result= queryRunner.query(connection,sql,new MapListHandler());
System.out.println(result);
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCTools.release(null, null, connection);
}
}
4.5 ScalarHandler
把结果集转为一个数值返回,这个数值可以是任意类型和String,Date等。
public void testScalarHandler(){
Connection connection=null;
try{
connection=JDBCTools.getConnection();
String sql="SELECT NAME FROM CUSTOMER WHERE ID=?";
Object result= queryRunner.query(connection,sql,new ScalarHandler(),2);
System.out.println(result);
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCTools.release(null, null, connection);
}
}
JDBC使用DBUtils的更多相关文章
- day16(jdbc进阶,jdbc之dbUtils)
1.jdbc进阶 jdbc事务管理 jdbc中的事务管理其实就是交给了连接对象去管理.先写一个简单的事务管理 public class Demo01 { private static Connecti ...
- jdbc框架-dbutils的简单使用
jdbc框架-dbutils的简单使用 dbutils:是apache组织的一个工具类,jdbc的框架,更方便我们使用 使用步骤: 1.导入jar包(commons-dbutils-1.4.jar) ...
- JDBC和DBUtils区别(查询时jdbc只能返回ResultSet需要po转vo,dbutils返回的BeanListHandler与BeanHandler对应集合与对象)
17:34 2013/6/7 JDBC //添加客户 public void addNewCustomer(Customer c) throws DAOException { Connection c ...
- 网络协议 finally{ return问题 注入问题 jdbc注册驱动问题 PreparedStatement 连接池目的 1.2.1DBCP连接池 C3P0连接池 MYSQL两种方式进行实物管理 JDBC事务 DBUtils事务 ThreadLocal 事务特性 并发访问 隔离级别
1.1.1 API详解:注册驱动 DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用 原因有2个: >导致驱动被注册2 ...
- JDBC、DBUtils
JDBC(Java Data Base Connectivity) java数据连接 可以为多种数据库,提供统一访问,它由一组用java语言编写的类和接口组成,也是java访问数据库的规范. my ...
- JDBC的DBUtils源码
DBUtils源码: package com.it.util; import java.sql.Connection; import java.sql.DriverManager; import ja ...
- 29_Java_数据库_第29天(JDBC、DBUtils)_讲义
今日内容介绍 1.JDBC 2.DBUtils 01JDBC概念和数据库驱动程序 * A: JDBC概念和数据库驱动程序 * a: JDBC概述 * JDBC(Java Data Base Conne ...
- JDBC及DBUtils
1.JDBC2.DBUtils ###01JDBC概念和数据库驱动程序 * A: JDBC概念和数据库驱动程序 * a: JDBC概述 * JDBC(Java Data Base Connectivi ...
- (二十二)自定义简化版JDBC(Dbutils框架的设计思想)
目录 元数据概念 DataBaseMetaData ParameterMetaData ResultSetMetaData 编写简化版的JDBC O-R Mapping 概念 自定义简化版JDBC 元 ...
随机推荐
- TCP BBR - 一键安装最新内核并开启 TCP BBR
原文地址: https://teddysun.com/489.html 最近,Google 开源了其 TCP BBR 拥塞控制算法,并提交到了 Linux 内核,从 4.9 开始,Linux 内核已经 ...
- “全栈2019”Java多线程第二十二章:饥饿线程(Starvation)详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- jzoj5931
根據打表可得,對於n的情況 任意一個首位!=1的排列時,則其答案-1可以與首位為1的情況對應 當n=4時 排列 答案 1 2 3 4 ------ 0 1 2 4 3 ------ 1 1 3 2 4 ...
- Java并发工具类之线程间数据交换工具Exchanger
Exchanger是一个用于线程间协做的工具类,主要用于线程间的数据交换.它提供了一个同步点,在这个同步点,两个线程可以彼此交换数据.两个线程通过exchange方法交换数据,如果一个线程执行exch ...
- ubuntu16.04配置java环境(重启后不会失效)
ubuntu16.04配置java环境(重启后不会失效) 1.jdk的安装包(.tar.gz)拷贝到/opt目录下 mv jdk-8u144-linux-x64.tar.gz /opt 2.解压文件 ...
- 布隆过滤器redis缓存
Bloom Filter布隆过滤器算法背景如果想判断一个元素是不是在一个集合里,一般想到的是将集合中所有元素保存起来,然后通过比较确定.链表.树.散列表(又叫哈希表,Hash table)等等数据结构 ...
- error: failed to push some refs to 'https://github.com/username/python.git'
解决error: failed to push some refs to 'https://github.com/bluepen/python.git' 当我们在使用git工具上传我们自己的代码时,可 ...
- NOIP2017滚粗记【下】
(续上篇) Day1: 下午,全竞赛队的人都在竞赛室颓~,再次吐槽下我校网管科的,下午普及考试又把竞赛室的网络切掉了,还好我们机制地准别了一堆单机游戏.普及组考完后,网络又恢复正常了,但晚上9点左右又 ...
- AngularJS入门之数据绑定
本篇我们看一下AngularJS中的数据绑定.虽然我们直到这篇才提到数据绑定,但事实上在前面几篇中我们已经非常熟练的运用AngularJS的数据绑定功能了! ngBind(ng-bind)/ {{ e ...
- RDLC_部署到不同的浏览器
首先我用的是vs2015 的reportview插件 在数据库中应该配置报表的服务器地址,在项目中添加ReportViewer 插件,单独用一个页面显示接收报表 <form id="f ...