DbUtils源码分析系列(一)

DbUtils源码结构

DbUtils当前版本是1.6,
源码下载地址:http://commons.apache.org/proper/commons-dbutils/download_dbutils.cgi

DbUtils源码分析系列(一)_第1张图片
下面简单描述一下每个包信息:
org.apache.commons.dbutils.handlers
提供ResultSetHandler接口实现,默认提供了10种实现。
DbUtils源码分析系列(一)_第2张图片

ResultSetHandler实现类 描述
ArrayHandler 把结果集中的第一行数据转成Object数组
ArrayListHandler 把结果集中的每一行数据都转成一个Object数组,再存放到List中
BeanHandler 将结果集中的第一行数据转成一个JavaBean实例
BeanListHandler 将结果集中的每一行数据都转成一个JavaBean实例,存放到List中
BeanMapHandler 将结果集中的每一行数据都转成一个JavaBean实例,并指定某一列对应的值作为Key,存放到Map中
ColumnListHandler 将结果集中某一列的数据存放到List中
KeyedHandler 将结果集中的每一行数据都封装到一个Map里,key是列名,再把这些Map存到另一个Map里,这个Map的Key为指定的某一个列对应的值
MapHandler 将结果集中的第一行数据封装到一个Map里,Key是列名,Value就是对应的值
MapListHandler 将结果集中的每一行数据都封装到一个Map里,Key是列名,然后再将Map存放到List
ScalarHandler 将结果集中的第一行的某一列转换成指定的Object

org.apache.commons.dbutils.wrappers
提供对java.sql.*类的包装功能。默认利用JDK动态代理功能提供了两个包装器:

包装器 描述
SqlNullCheckedResultSet 包装一个结果集,使getString和getObject方法返回的String为trim String
StringTrimmedResultSet 包装一个结果集,检查getXXX方法返回值。如果不为空,直接返回列值;如果列值为空,默认返回java默认值或者该实例中指定的值

org.apache.commons.dbutils
这个包中包含了DbUtils核心类和接口—— 其中DbUtils, QueryRunner and the ResultSetHandler 接口是我们首先应该关注的。后文将做详细分析。

测试依赖

<dependencies>
    <dependency>
      <groupId>junitgroupId>
      <artifactId>junitartifactId>
      <version>4.11version>
      <scope>testscope>
    dependency>
    <dependency>
      <groupId>org.mockitogroupId>
      <artifactId>mockito-coreartifactId>
      <version>1.9.5version>
      <scope>testscope>
    dependency>
    <dependency>
      <groupId>org.hamcrestgroupId>
      <artifactId>hamcrest-allartifactId>
      <version>1.3version>
      <scope>testscope>
    dependency>
  dependencies>

你可能感兴趣的:(DButils)