1、概述

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

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

  (3)commons-dbutils-1.6-bin.zip 链接:commons-dbutils-1.6-bin.zip 密码:r1z4 ;

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

  (5)DBUtils封装了对JDBC的操作,简化了JDBC操作,可以少写代码;

  (6)Dbutils三个核心功能介绍:

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

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

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

2、QueryRunner核心类

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

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

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

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

  (2)添加

 import java.sql.Connection;
import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunner; public class TestDBUtils {
public static void main(String[] args) {
try {
// 获取一个用来执行SQL语句的对象 QueryRunner
QueryRunner qr = new QueryRunner(); String sql = "INSERT INTO sort(sname) VALUES(?)";
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);
} } }

  (3)更新

 import java.sql.Connection;
import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunner; public class TestDBUtils {
public static void main(String[] args) {
try {
// 获取一个用来执行SQL语句的对象 QueryRunner
QueryRunner qr = new QueryRunner(); String sql = "UPDATE sort set sid=sid+1 WHERE sname=?";
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);
} } }

  (4)删除

 import java.sql.Connection;
import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunner; public class TestDBUtils {
public static void main(String[] args) {
try {
// 获取一个用来执行SQL语句的对象 QueryRunner
QueryRunner qr = new QueryRunner(); String sql = "DELETE FROM sort WHERE sname=?";
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);
} } }

4、QueryRunner实现查询操作

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

  (2)ResultSetHandler结果集处理类

  

  (3)JavaBean

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

    ①需要实现接口:java.io.Serializable ,通常实现接口这步骤省略了,不会影响程序;

    ②提供私有字段:private 类型 字段名;

    ③提供getter/setter方法;

    ④提供无参构造。

 public class Sort {
private int sid;
private String sname; public Sort() {
super();
} public int getSid() {
return sid;
} public void setSid(int sid) {
this.sid = sid;
} public String getSname() {
return sname;
} public void setSname(String sname) {
this.sname = sname;
} @Override
public String toString() {// 该方法可以省略
return "Sort[sid=" + sid + ",sname=" + sname + "]";
}
}

  (4)ArrayHandler与ArrayListHandler查询

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

 import java.sql.Connection;
import java.sql.SQLException;
import java.util.Arrays; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayHandler;
import org.junit.Test; public class ArrayHandlerDemo { @Test
public void method() {
try {
// 获取QueryRunner对象
QueryRunner qr = new QueryRunner();
// 执行SQL语句
String sql = "SELECT * FROM sort";
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();
}
}
}

1024x768

  运行结果:

  

  

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

 import java.sql.Connection;
import java.sql.SQLException;
import java.util.Arrays;
import java.util.List; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayListHandler;
import org.junit.Test; public class ArrayListHandlerDemo {
@Test
public void method() {
try {
// 获取QueryRunner对象
QueryRunner qr = new QueryRunner();
// 执行SQL语句
String sql = "SELECT * FROM sort WHERE sid>?";
Object[] params = { 4 };
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();
}
}
}

  运行结果:

  

  

  (5)BeanHandler与BeanListHandler查询

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

 import java.sql.Connection;
import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler; public class BeanHandlerDemo {
public static void main(String[] args) { try {
// 获取QueryRunner
QueryRunner qr = new QueryRunner();
// 执行SQL语句
String sql = "SELECT * FROM sort WHERE sname=?";
Object[] params = { "冰箱" };
Connection conn = JDBCUtils.getConnection();
Sort s = qr.query(conn, sql, new BeanHandler<Sort>(Sort.class),
params);
// 结果集处理
System.out.println(s); conn.close();
} catch (SQLException e) {
throw new RuntimeException(e);
} }
}

  运行结果:

  
  

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

 import java.sql.Connection;
import java.sql.SQLException;
import java.util.List; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.junit.Test; public class BeanListHandlerDemo {
@Test
public void method() {
try {
// 获取QueryRunner
QueryRunner qr = new QueryRunner();
// 执行SQL语句
String sql = "SELECT * FROM Sort WHERE sid>?";
Object[] params = { 4 };
Connection conn = JDBCUtils.getConnection();
List<Sort> list = qr.query(conn, sql, new BeanListHandler<Sort>(
Sort.class), params);
// 结果集处理
for (Sort s : list) {
System.out.println(s);
} conn.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}

  运行结果:

  

  

  温馨提示:使用DBUtils查询数据,如果使用ArrayListHandler等都能够返回正确值,<br>但使用BeanListHandler 和 BeanHandler则一直返回null,请检查保证实体类的属性名称必须要同数据库中的字段一模一样(区分大小写)。

  (6)ColumnListHandler与ScalarHandler查询

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

 import java.sql.Connection;
import java.sql.SQLException;
import java.util.List; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ColumnListHandler;
import org.junit.Test; public class ColumnListHandlerDemo {
@Test
public void method() {
try {
// 获取QueryRunner对象
QueryRunner qr = new QueryRunner();
// 执行SQL语句
String sql = "SELECT sname FROM Sort WHERE sid>?";
Object[] params = { 4 };
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();
}
}
}

  运行结果:

  

  

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

 import java.sql.Connection;
import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Test; public class ScalarHandlerDemo {
@Test
public void method() {
try {
// 获取QueryRunner对象
QueryRunner qr = new QueryRunner(); // 执行SQL语句
String sql = "SELECT MAX(sid) FROM Sort";
Object[] params = {};
Connection conn = JDBCUtils.getConnection();
Integer max = qr.query(conn, sql, new ScalarHandler<Integer>(),
params);
// 结果集的处理
System.out.println("max=" + max); conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}

  运行结果:

  

  

Normal
0

7.8 磅
0
2

false
false
false

EN-US
ZH-CN
X-NONE

/* Style Definitions */
table.MsoNormalTable
{mso-style-name:普通表格;
mso-tstyle-rowband-size:0;
mso-tstyle-colband-size:0;
mso-style-noshow:yes;
mso-style-priority:99;
mso-style-qformat:yes;
mso-style-parent:"";
mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
mso-para-margin:0cm;
mso-para-margin-bottom:.0001pt;
mso-pagination:widow-orphan;
font-size:10.5pt;
mso-bidi-font-size:11.0pt;
font-family:"Calibri","sans-serif";
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:宋体;
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-bidi-font-family:"Times New Roman";
mso-bidi-theme-font:minor-bidi;
mso-font-kerning:1.0pt;}

03015_DBUtils的更多相关文章

随机推荐

  1. Ubuntu 10.04 右上角网络管理图标消失的解决的方法

           那个显示网络状态的那个图标.叫做:network-manager.假设是有线网络连接的话.是上下两个箭头,假设是无线网络的话.是一个发射信号的形状. sudo gedit /etc/Ne ...

  2. SPOJ 题目705 New Distinct Substrings(后缀数组,求不同的子串个数)

    SUBST1 - New Distinct Substrings no tags  Given a string, we need to find the total number of its di ...

  3. Windows server 2008 布署FTP服务器实例(适用于阿里云)!

    Windows server 2008 布署FTP服务器实例(适用于阿里云). 1.打开管理.配置-用户-新建用户,如:ftp_user,并设置password.选择永只是期和password不能更改 ...

  4. spark 从RDD createDataFrame 的坑

    Scala: import org.apache.spark.ml.linalg.Vectors val data = Seq( (7, Vectors.dense(0.0, 0.0, 18.0, 1 ...

  5. PUBG

    题目描述 最近,喜爱ACM的PBY同学沉迷吃鸡,无法自拔,于是又来到了熟悉的ERANGEL.经过一番搜寻,PBY同学准备动身前往安全区,但是,地图中埋伏了许多LYB,PBY的枪法很差,希望你能够帮他找 ...

  6. 洛谷1019 单词接龙 字符串dfs

    问题描述 单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重合 ...

  7. 是我太天真之被BUG按在地上疯狂摩擦

    事情是这样的,我是一个追求完美的人,特别喜欢锦上添花,去年在学习python的时候做了一个作业:多重剪贴板,今天大概是吃饱了,查了一下自己的头发以后,我觉得可以挑战一下自己,所以决定为那个小程序添加一 ...

  8. 题解 P3521 【[POI2011]ROT-Tree Rotations】

    这道题采用权值线段树合并的解法. 首先讲一下解法中出现的两个概念:权值线段树与线段树合并. 所谓权值线段树,可以理解为维护的信息反过来的普通线段树,我个人认为值域线段树这个名字其实要准确一些. 举个例 ...

  9. 【Codeforces Beta Round #45 D】Permutations

    [题目链接]:http://codeforces.com/problemset/problem/48/D [题意] 给你n个数字; 然后让你确定,这n个数字是否能由若干个(1..x)的排列连在一起打乱 ...

  10. Java基础学习总结(15)——java读取properties文件总结

    一.java读取properties文件总结 在java项目中,操作properties文件是经常要做的,因为很多的配置信息都会写在properties文件中,这里主要是总结使用getResource ...