•commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装。学习成本极低。而且使用dbutils能极大简化jdbc编码的工作量,同一时候也不会影响程序的性能。

•API介绍:

–org.apache.commons.dbutils.QueryRunner

–org.apache.commons.dbutils.ResultSetHandler

–工具类

•org.apache.commons.dbutils.DbUtils。


QueryRunner类有两类主要方法:

query() : 用于查询数据

update() : 用于增删改


ResultSetHandler接口用与将查询到的数据按要求转换为还有一种格式。


•ArrayHandler:把结果集中的第一行数据转成对象数组。

•ArrayListHandler:把结果集中的每一行数据都转成一个数组,再存放到List中。

•BeanHandler:将结果集中的第一行数据封装到一个相应的JavaBean实例中。

•BeanListHandler:将结果集中的每一行数据都封装到一个相应的JavaBean实例中,存放到List里。
•ColumnListHandler:将结果集中某一列的数据存放到List中。
•KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里,再把这些map再存到一个map里,其key为指定的key。
•MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是相应的值。

•MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List


-------------------------------------------------下面为详细的Demo--------------------------------------------------------------

QueryRunner.update()

<span style="font-size:14px;">	/**
* 測试 QueryRunner 类的 update 方法
* 该方法可用于 INSERT, UPDATE 和 DELETE
*/
@Test
public void testQueryRunnerUpdate() {
//1. 创建 QueryRunner 的实现类
QueryRunner queryRunner = new QueryRunner(); String sql = "DELETE FROM customers " +
"WHERE id IN (?,?)"; Connection connection = null; try {
connection = JDBCTools.getConnection();
//2. 使用其 update 方法
queryRunner.update(connection,
sql, 12, 13);
} catch (Exception e) {
e.printStackTrace();
} finally{
JDBCTools.releaseDB(null, null, connection);
} }</span>

BeanHandler:把结果集的第一条记录转为创建BeanHandler对象时传入的Class參数相应的对象.

<span style="font-family:SimSun;font-size:14px;"><span style="font-size:14px;font-weight: normal;">public void testBeanHandler() {

		QueryRunner queryRunner = new QueryRunner();
Connection conn = null; try {
conn = JDBCTools.getConnection();
String sql = "SELECT id, name customerName, email, birth "
+ "FROM customers WHERE id>=?";
Customer customer = queryRunner.query(conn, sql, new BeanHandler(
Customer.class), 5); System.out.println(customer);
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCTools.releaseDB(null, null, conn);
}
}</span></span>

BeanListHandler:把结果集转为一个List,该List不为null,但可能为空集合(即size()方法返回0)

<span style="font-family:SimSun;font-size:14px;">public void testBeanListHandler(){
String sql = "SELECT id, name customerName, email, birth " +
"FROM customers"; QueryRunner queryRunner = new QueryRunner(); Connection conn = null; try {
conn = JDBCTools.getConnection(); Object object = queryRunner.query(conn, sql,
new BeanListHandler<>(Customer.class)); System.out.println(object);
} catch (Exception e) {
e.printStackTrace();
} finally{
JDBCTools.releaseDB(null, null, conn);
}
}</span>

MapHandler:返回SQL语句相应的第一条记录相应的Map对象.键:SQL查询的列名(不是列的别名),值:列的值.

<span style="font-family:SimSun;font-size:14px;"><span style="font-size:14px;font-weight: normal;">public void testMapHandler(){
Connection connection = null;
QueryRunner queryRunner = new QueryRunner(); String sql = "SELECT id, name customerName, email, birth " +
"FROM customers WHERE id = ? "; try {
connection = JDBCTools.getConnection();
Map<String, Object> map = queryRunner.query(connection,
sql, new MapHandler(), 4); System.out.println(map);
} catch (Exception e) {
e.printStackTrace();
} finally{
JDBCTools.releaseDB(null, null, connection);
}
}</span></span>

MapLiatHandler:将结果转化为一个Map的List. MapLiatHandler:返回的多条记录相应的Map的集合.

<span style="font-family:SimSun;font-size:14px;font-weight: normal;">public void testMapListHandler(){
Connection connection = null;
QueryRunner queryRunner = new QueryRunner(); String sql = "SELECT id, name, email, birth " +
"FROM customers"; try {
connection = JDBCTools.getConnection();
List<Map<String, Object>> mapList = queryRunner.query(connection,
sql, new MapListHandler()); System.out.println(mapList);
} catch (Exception e) {
e.printStackTrace();
} finally{
JDBCTools.releaseDB(null, null, connection);
}
}</span>

ScalarHandler:把结果集转为一个数值(能够是随意类型)返回

<span style="font-family:SimSun;">public void testScalarHandler(){
Connection connection = null;
QueryRunner queryRunner = new QueryRunner(); String sql = "SELECT name FROM customers " +
"WHERE id = ?"; try {
connection = JDBCTools.getConnection();
Object count = queryRunner.query(connection, sql,
new ScalarHandler(), 6); System.out.println(count);
} catch (Exception e) {
e.printStackTrace();
} finally{
JDBCTools.releaseDB(null, null, connection);
}
}</span>





最新文章

  1. 手机端访问web调用数字键盘。
  2. 那些PHP中没有全称的简写
  3. go outside @ CULTS LYRICS
  4. iOS-多线程-内存管理
  5. ! cocos2d sprintf的问题
  6. Java基础之创建窗口——使用边界布局管理器(TryBorderLayout)
  7. Git服务器搭建及SSH无密码登录设置
  8. DDDD
  9. 【Asp.Net MVC--资料汇总】杂七杂八
  10. php curl抓取远程页面内容的代码
  11. ubuntu下设置开机自启动项
  12. 有时summary的状态和details是否有open属性有关
  13. Dubbo有意思的特性介绍
  14. LoadRunner性能测试工具
  15. midi文件格式
  16. T4设计时模板调试
  17. 微信小程序——创建自己的第一个小程序【一】
  18. TF之RNN:TensorBoard可视化之基于顺序的RNN回归案例实现蓝色正弦虚线预测红色余弦实线—Jason niu
  19. C# 调用程序集方法
  20. Git:合并分支冲突问题

热门文章

  1. tail---显示文件中的尾部内容
  2. HDU 2253 Longest Common Subsequence Again
  3. 浴谷 P1768 天路
  4. 一、 Hbase特性 3v特性,Volume(量级) Varity(种类) Velocity(速度)
  5. 火狐不支持innerText属性,只支持innerHTML属性
  6. DICOM:Transfer Syntax传输语义之奇葩GE Private TS
  7. 做一个萌萌哒的button之box-shadow
  8. CAShapeLayer的简单介绍以及基本使用
  9. c++动态库中使用命名空间的问题
  10. axure中使用HighCharts模板制作统计图表