[Apache commons系列]DBUtils简介-2.核心类简介

  inkfish原创,请勿商业性质转载,转载请注明来源(http://blog.csdn.net/inkfish )。

  DbUtils是一个小型的类库,不需要也不值得花太长的时间去熟悉每一个类。DbUtils核心其实只有三个类/接口,即QueryRunnerResultSetHandlerDbUtls (官方文档中写的是前两个)。(来源:http://blog.csdn.net/inkfish)

 

一.下面先过一下DbUtils的几个包(package):(来源:http://blog.csdn.net/inkfish)

1.org.apache.commons.dbutils
  提供核心类/接口,提供最常用最通用的功能。(来源:http://blog.csdn.net/inkfish)

2.org.apache.commons.dbutils.handlers
  提供对ResultSet 的各种形式的包装,所有类都实现了ResultSetHandler ,因此也可以看做是ResultSetHandler 的延伸。其功能比如把ResultSet 中每一行变成一个JavaBean或一个数组等。(来源:http://blog.csdn.net/inkfish)

3.org.apache.commons.dbutils.wrappers
  提供对ResultSet 中的值的包装过滤,所有类都实现了java.lang.reflect.InvocationHandler 。其功能比如将ResultSet 中所有String 值进行trim() 操作,或是把所有null值赋一个有意义的新值。(来源:http://blog.csdn.net/inkfish)

 

二.下面是对DbUtils各类的使用进行介绍:(来源:http://blog.csdn.net/inkfish)

1.org.apache.commons.dbutils.DbUtils
  DbUtils类是一个工具类,里面所有方法都是静态的,因此无需实例化即可调用,通过API介绍即可了解其功能:(来源:http://blog.csdn.net/inkfish)

  • close :关闭ConnectionStatementResultSet ,忽略null;
  • closeQuietly :安静的关闭ConnectionStatementResultSet ,它会尽力去关闭,忽略null和SQLException
  • commitAndClose :提交并关闭Connection ,忽略null;
  • commitAndCloseQuietly :提交并关闭Connection ,忽略null和SQLException
  • loadDriver :和Class.forName().newInstance() 功能一样,但它能捕获异常,并返回truefalse
  • printStackTrace :打印SQLException 的详细错误信息;
  • printWarnings :打印Connection 的警告信息;
  • rollback :回滚操作,忽略null;
  • rollbackAndClose :回滚操作并关闭,忽略null;
  • rollbackAndCloseQuietly :回滚操作并关闭,忽略null、SQLException

2.org.apache.commons.dbutils.QueryRunner (来源:http://blog.csdn.net/inkfish)

  • batch :执行成批的INSERT、UPDATE、DELETE操作;
  • fillStatement :用Object[] 或JavaBean的值填充PreparedStatement 中的占位符;
  • query :执行查询操作(StatementPreparedStatement 均可),并用ResultSetHandler 来处理ResultSet
  • update :执行INSERT或UPDATE操作(StatementPreparedStatement 均可)。

3.org.apache.commons.dbutils.ResultSetHandler
  所有在DbUtils里提供的的ResultSetHandler 实现都是线程安全的

  • ArrayHandler :把ResultSet 第一行包装成Object[]
  • ArrayListHandler :把ResultSet包装成List<Object[]>
  • BeanHandler :把ResultSet 第一行包装成一个JavaBean;
  • BeanListHandler :把ResultSet 第一行包装成一个List<JavaBean>
  • ColumnListHandler :抽取ResultSet 指定的列,以List<Object> 对象的形式返回,默认第一列;
  • KeyedHandler :包装ResultSet ,以Map<Object,Map<String,Object>> 对象形式返回,第一个Object 是指定的列值,第二个MapString 是列名;
  • MapHandler :把ResultSet 第一行包装成Map<String, Object>
  • MapListHandler :把ResultSet包装成List<Map<String,Object>>
  • ScalarHandler :抽取ResultSet 第一行指定列,以Object 对象形式返回。

4.org.apache.commons.dbutils.wrappers.SqlNullCheckedResultSet
  对ResultSet 中的null值进行处理。

5.org.apache.commons.dbutils.wrappers.StringTrimmedResultSet
  对ResultSet 中的String 进行trim() 处理。(来源:http://blog.csdn.net/inkfish)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值