common-dbutils.jar是Apache组织提供的一个对JDBC进行简单封装的开源工具类库,使用它能够简化JDBC应用程序的开发,同时也不会影响程序的性能。

1、QueryRunner类

①update方法:

  • int update(String sql,Object...params) -->可执行增删改语句
  • int update(Connection con,String sql,Object...params)-->需要调用者提供Connection,这说明本方法不再管理Connection。支持事务。

②query方法:

  • T query(String sql,ResultSetHandler rsh,Object...params)-->可执行查询

    • 它会先得到ResultSet,然后调用rsh的handle()把rs转换成需要的类型。
  • T query(Connection con,String sql,ResultSetHandler rsh,Object...params);支持事务。

2、ResultSetHandler接口:

  • BeanHandler(单行)-->构造器需要一个Class类型参数,用来把一行结果转换成指定类型的javabean对象。
  • BeanListHandler(多行)-->构造器也是需要一个Class类型的参数,用来把一行结果集转换成一个javabean,那么多行就是转换成List对象,一堆javabean
  • MapHandler(单行)-->把一行结果集转换成Map对象
    • 一行记录:
    • sid     sname   age   gender
    • 1001     zs         99     male
    • 一个Map:
    • {sid:1001, sname:zs, age:99, gender:male}
  • MapListHandler(多行) -->把一行记录转换成一个Map,多行就是多个Map,即List<Map>.
  • ScalarHandler(单行单列) -->通常用与“SELECT COUNT(*) FROM t_stu;”语句,结果集是单行单列的,它返回一个Object。

3、示例:

 1 import cn.itcast.jdbc.JdbcUtils;
2 import org.apache.commons.dbutils.QueryRunner;
3 import org.apache.commons.dbutils.handlers.*;
4 import org.junit.Test;
5 import java.sql.SQLException;
6 import java.util.List;
7 import java.util.Map;
8
9 public class Demo3 {
10 @Test
11 public void fun1() throws SQLException {
12 QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
13 String sql = "INSERT INTO t_stu VALUES(?,?,?,?)";
14 Object[] params = {1002,"lisi",99,"female"};
15 qr.update(sql,params);
16 }
17 @Test
18 public void fun2() throws SQLException {
19 //创建QueryRunner,提供数据库连接池对象
20 QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
21 //给出sql模板
22 String sql = "SELECT * FROM t_stu WHERE sid=?";
23 //给出参数
24 Object[] params = {1002};
25 //执行query()方法,需要给出集处理器,即 ResultSetHandler的实现类对象
26 //我们需要给的是BeanHandler,它实现了ResultSetHandler
27 //它需要一个类型,然后它会把rs中的数据封装到指定类型的javabean对象中,然后返回javabean对象
28 Stu stu = qr.query(sql,new BeanHandler<Stu>(Stu.class),params);
29 System.out.println(stu);
30 }
31 //BeanListHandler的应用,它是多行处理器
32 //每行对象一个Stu对象
33 @Test
34 public void fun3() throws Exception{
35 QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
36 String sql = "SELECT * FROM t_stu";
37 List<Stu> stuList = qr.query(sql,new BeanListHandler<Stu>(Stu.class));
38 System.out.println(stuList);
39 }
40
41 //MapHandler的应用,它是单行处理器,把一行转换成一个Map对象
42 @Test
43 public void fun4() throws Exception{
44 QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
45 String sql = "SELECT * FROM t_stu WHERE sid=?";
46 Object[] params = {1001};
47 Map map = qr.query(sql,new MapHandler(),params);
48 System.out.println(map);
49 }
50
51 //MapListHandler,它是多行处理器,把每行都转换成一个Map,即List<Map>
52 @Test
53 public void fun5() throws Exception{
54 QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
55 String sql = "SELECT * FROM t_stu ";
56 List<Map<String,Object>> mapList = qr.query(sql,new MapListHandler());
57 System.out.println(mapList);
58 }@Test
59 //ScalarHandler,它是单行单列时使用,最为合适。
60 public void fun6() throws Exception{
61 QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
62 String sql = "SELECT COUNT(*) FROM t_stu ";
63 Number cnt = (Number) qr.query(sql,new ScalarHandler());
64 long c = cnt.longValue();
65 System.out.println(c);
66 }
67 }
 1 import com.mchange.v2.c3p0.ComboPooledDataSource;
2 import java.sql.Connection;
3 import java.sql.SQLException;
4
5 public class JdbcUtils {
6 //配置文件的默认配置,要求你必须给出从c3p0-config.xml
7 private static ComboPooledDataSource dataSource = new ComboPooledDataSource();
8 //使用连接池返回一个连接对象
9 public static Connection getConnection() throws SQLException {
10 return dataSource.getConnection();
11 }
12 //返回连接池对象
13 public static ComboPooledDataSource getDataSource() {
14 return dataSource;
15 }
16 }

DBUtils结果集处理器介绍的更多相关文章

  1. SharePoint网站集功能介绍

    SharePoint网站集功能介绍 https://support.office.com/zh-cn/article/%E5%90%AF%E7%94%A8%E6%88%96%E7%A6%81%E7%9 ...

  2. 集群介绍 keepalived介绍 用keepalived配置高可用集群

    集群介绍 • 根据功能划分为两大类:高可用和负载均衡 • 高可用集群通常为两台服务器,一台工作,另外一台作为冗余,当提供服务的机器宕机,冗余将接替继续提供服务 • 实现高可用的开源软件有:heartb ...

  3. nginx 集群介绍

    nginx 集群介绍 完成一次请求的步骤 1)用户发起请求 2)服务器接受请求 3)服务器处理请求(压力最大) 4)服务器响应请求 缺点:单点故障 单台服务器资源有限 单台服务器处理耗时长 ·1)部署 ...

  4. Linux集群介绍、keepalived介绍及配置高可用集群

    7月3日任务 18.1 集群介绍18.2 keepalived介绍18.3/18.4/18.5 用keepalived配置高可用集群扩展heartbeat和keepalived比较http://blo ...

  5. 负载均衡集群介绍、LVS介绍、LVS调度算法、LVS NAT模式搭建

    7月4日任务 18.6 负载均衡集群介绍18.7 LVS介绍18.8 LVS调度算法18.9/18.10 LVS NAT模式搭建 扩展lvs 三种模式详解 http://www.it165.net/a ...

  6. Jmeter元件——JSON Extractor后置处理器介绍2

    在前段时间将JSON Extractor元件做了个简单的介绍:Jmeter元件——JSON Extractor后置处理器介绍1,今天以一个具体的json,以不同的方式提取数据做个详细的介绍. 一.模拟 ...

  7. Linux centosVMware 负载均衡集群介绍、LVS介绍、LVS调度算法、LVS NAT模式搭建

    一.负载均衡集群介绍 主流开源软件LVS.keepalived.haproxy.nginx等 其中LVS属于4层(网络OSI 7层模型),nginx属于7层,haproxy既可以认为是4层,也可以当做 ...

  8. Linux centosVMware 集群介绍、keepalived介绍、用keepalived配置高可用集群

    一.集群介绍 根据功能划分为两大类:高可用和负载均衡 高可用集群通常为两台服务器,一台工作,另外一台作为冗余,当提供服务的机器宕机,冗余将接替继续提供服务 实现高可用的开源软件有:heartbeat. ...

  9. QueryRunner(DBUtils) 结果集实例

    转自:http://www.cnblogs.com/myit/p/4272824.html#   单行数据处理:ScalarHandler    ArrayHandler    MapHandler  ...

随机推荐

  1. [Objective-C语言教程]数据封装(27)

    所有Objective-C程序都由以下两个基本要素组成 - 程序语句(代码) - 这是执行操作的程序的一部分,它们被称为方法(函数). 程序数据 - 数据是受程序功能影响的程序信息. 封装是一种面向对 ...

  2. JSP入门之自定义标签

    第二部分简单讲解:主要讲解el表达式,核心标签库.本章主要讲解:自定义标签库:404页面,505页面,错误页面配置方法 全部代码下载:链接 1.JSP自定义标签: 自定义标签是用户定义的JSP语言元素 ...

  3. Dota2APP--第一天

    从今天开始,下定决心自己独立开发一个有关于Dota2的APP,因为非常喜欢这个游戏恰好自己又是做iOS移动开发的所以萌生了这个想法.希望可以坚持下去,有喜欢dota2的朋友也可以提点建议. 一.项目的 ...

  4. 线索二叉树的理解和实现(Java)

    线索二叉树的基本概念 我们按某种方式对二叉树进行遍历,将二叉树中所有节点排序为一个线性序列,在该序列中,除第一个结点外每个结点有且仅有一个直接前驱结点:除最后一个结点外每一个结点有且仅有一个直接后继结 ...

  5. 2016级算法第六次上机-E.Bamboo之吃我一拳

    Bamboo之吃我一拳 分析 当两个点的距离<=d时,才可以出拳,想要使得满足出拳条件的点对最少但不为0 寻找最近点对距离,得到的最近距离能够使得可以出拳的组数最少,因为除了最近点对外其他组合均 ...

  6. SSAS 收藏

    1.多事实表 SQL实现和SSAS中MDX实现的差异 2.层次结构 3.MDX常用几种查询对比 4.一段话理解 MDX中的Select .轴.COLUMNS.ROWS 5.[转载]MSDN-MDX#0 ...

  7. 解决Visual C++ Redistributable for Visual Studio 2015的安装问题(摘录)

    1. Visual C++ Redistributable for Visual Studio 2015系统要求:Windows 7情况下必须是Windows 7 with SP1.或者Windows ...

  8. Linux下ls命令使用详解(转)

    说明:我们在linux下使用ll时,其实就是ls -l.ls才是最终的命令程序. ls命令是linux下最常用的命令之一,ls跟dos下的dir命令是一样的都是用来列出目录下的文件,List即列表的意 ...

  9. JS检测数据类型

    如果你要判断的是基本数据类型或JavaScript内置对象,使用toString: 如果要判断的时自定义类型,请使用instanceof. 1.typeof typeof操作符返回的是类型字符串,它的 ...

  10. 《LeetBook》leetcode题解(12):Integer to Roman[M]

    我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...