设为首页 加入收藏

TOP

DBUtils结果集处理器介绍(一)
2017-10-11 15:22:49 】 浏览:3488
Tags:DBUtils 结果 处理器 介绍

  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 COUN
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇java.lang.OutOfMemoryError: Per.. 下一篇Java continue break 制作简单聊..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目