注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

0与1构筑世界,程序员创造时代

软件架构设计 Java编程

 
 
 

日志

 
 

Apache Commons DbUtils 源码分析 | Apache Commons DbUtils Source Code Analysis  

2014-06-13 20:12:53|  分类: 软件架构与设计 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

上一篇文章Apache DbUtils 使用教程详细讲解了DbUtils的特性和使用方法,如果你厌倦了Hibernate的笨重,也不想用IBatis,建议试试DbUtils,你会发现真的很轻量,一切尽在掌控中。

这篇文章我们继续讲解DbUtils的原理和实现。

概述

DbUtils有三个主要的组件:

  • QueryRunner
  • ResultSetHandler
  • RowProcessor

它们的关系如下图所示。QueryRunner在执行查询的SQL语句后,调用ResultSetHandler将ResultSet转换成指定的对象,DbUtils自带的ResultSetHandler实现类都是调用RowProcessor转换行记录。

Apache DbUtils 源码分析 | Apache DbUtils Source Code Analysis - 傲风 - 0与1构筑世界,程序员创造时代

QueryRunner

QueryRunner是DbUtils执行查询、更新和插入操作的入口服务类。实现了同步和异步服务,QueryRunner提供同步服务,AsyncQueryRunner提供异步服务,它们都继承自AbstractQueryRunner。

 Apache DbUtils 源码分析 | Apache DbUtils Source Code Analysis - 傲风 - 0与1构筑世界,程序员创造时代

提供的功能有:

  • query方法。可执行查询操作SQL,如:select * from table。
  • update方法。可执行更新和删除操作SQL,如:update table set b=’b1’ where a=’a’,delete from table where a=’a’。
  • batch方法。可执行更新和删除SQL的批量操作,如:update table set b=? where a=?。
  • insert方法。可执行插入操作SQL,如:insert into table(a, b) values(‘a’, ‘b’)。

上述四种类型的方法均提供两种操作方式:

  1. 创建QueryRunner实例时传入DataSource实例,即可使用无需Connection参数的方法。例:
    QueryRunner run = new QueryRunner(ds);
    result = run.query(sql, handler);
    
    QueryRunner会帮你自动创建Connection、Statement、ResultSet实例,并安全地关闭它们。
  2. 创建QueryRunner实例时未传入DataSource实例,在调用方法时传入Connection。例:
    QueryRunner run = new QueryRunner();
    result = run.query(conn, sql, handler);
    
    QueryRunner会帮你自动创建Statement、ResultSet实例,并安全地关闭它们。但不会帮你关闭Connection。

ResultSetHandler

ResultSetHandler负责将查询的结果集ResultSet转换成指定的对象,DbUtils自带了许多实现。如下图所示:

Apache DbUtils 源码分析 | Apache DbUtils Source Code Analysis - 傲风 - 0与1构筑世界,程序员创造时代

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

RowProcessor

RowProcessor有一个默认的实现类BasicRowProcessor,DbUtils自带的ResultSetHandler实现类都是用BasicRowProcessor转换行数据。

Apache DbUtils 源码分析 | Apache DbUtils Source Code Analysis - 傲风 - 0与1构筑世界,程序员创造时代

<正文结束>

文章声明


作者:傲风(aofengblog@163.com)       编写时间:2014年06月13日

网址:http://aofengblog.blog.163.com

作者保留所有权利,转载请保留文章全部内容或者说明原作者和转载地址!

  评论这张
 
阅读(1206)| 评论(1)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017