dbUtils是对JDBC的完全封装,只需要导入连接池,添加sql语句,dbUtils就可以返回各种封装形式的结果集。
如果纯手动的话,在DAO层使用JDBC查询一个语句的话,需要以下几步:
1创建Connection对象
2创建PreparedStatement对象
3创建sql语句
4使用PreparedStatement对象的Query() Update()等查询更新方法,获取ResultSet结果集。
5对查询结果集进行封装,有可能封装成Bean/集合等。
6关闭各个对象
(期间还要做很多异常处理,整个代码全是try-catch块,非常难看)

但是dbUtils能做到的就是
1创建dbUtils封装对象,并传入DataSource连接池资源
2创建sql语句,可以是预编译类型的含参数sql语句 例如 select * from where ? = ?;
3获取dbUtils封装对象返回的结果集
-----------------------------------
    dbutils核心
        1.QueryRunner类
            它是用于执行sql语句的类。
            1.query 用于执行select
            2.update 用于执行update delete insert
            3.batch 批处理
        2.ResultSetHandler接口
            用于定义结果集的封装
            它提供九个实现类,可以进行不同的封装。
        3.DbUtils类
            它提供关于关闭资源以及事务rollback,commit操作。
Dbutlis详解
        1.QueryRunner
            1.QueryRunner怎样获取
                1.new QueryRunner()
                    如果是使用这种构造创建的QueryRunner,它的事务是手动控制.
                2.new QueryRunner(DataSource ds);
                    如果是使用这种构造,它的事务是自动事务,简单说,一条sql一个事务。

            2.QueryRunner中的三个核心方法
                query
                update
                batch
                对于上述三个方法,它们提供很多重载。
                如果QueryRunner在创建时,没有传递DataSource参数,那么在使用
                query,update,batch方法时,要传递Connection参数
                如果QueryRunner在创建时,传递了Dataource参数,好么在使用
                query,update,batch方法时,不需要传递Connection参数。

            总结:
                怎样配套使用:
                    QueryRunner runner=new QueryRunner();
                    runner.query(Connection,sql,ResultSetHandler,Object... param);
                    runner.update(Connection,sql,Object...param);
                    runner.batch(Connection con,sql,Object[][] objs);

                    QueryRunner runner=new QueryRunner(DataSource ds);
                    runner.query(sql,ResultSetHandler,Object... param);
                    runner.update(sql,Object...param);
                    runner.batch(sql,Object[][] objs);

        -----------------------------------------------------------------
        ResultSetHandler接口
            用于封装结果集.
            -----------
并且,这个结果集有9种封装的形式。
ResulsetHandler九个实现类

             ArrayHandler, 将结果集中第一条记录封装到Object[],数组中的每一个元素就是记录中的字段值。
             ArrayListHandler, 将结果集中每一条记录封装到Object[],数组中的每一个元素就是记录中的字段值。在将这些数组装入到List集合。

             BeanHandler(重点), 将结果集中第一条记录封装到一个javaBean中。
             BeanListHandler(重点), 将结果集中每一条记录封装到javaBean中,在将javaBean封装到List集合.

             ColumnListHandler, 将结果集中指定列的值封装到List集合.

             MapHandler, 将结果集中第一条记录封装到Map集合中,集合的 key就是字段名称,value就是字段值
             MapListHandler, 将结果集中每一条记录封装到Map集合中,集合的 key就是字段名称,value就是字段值,在将这些Map封装到List集合

             KeyedHandler,在使用指定的列的值做为一个Map集合的key,值为每一条记录的Map集合封装。
             ScalarHandler 进行单值查询 select count(*) from account;

package com.customer.dao;

import java.sql.SQLException;
import java.util.List;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;

import com.customer.domain.Customer;
import com.customer.utils.DataSourceUtils;

public class CustomerDao {

        public List<Customer> findAll() throws SQLException {
                String sql = "select * from customer";
                QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());
                return runner.query(sql, new BeanListHandler(Customer.class));
        }

}

dbUtils的基本使用的更多相关文章

  1. dbutils基本使用

    dbutils的查询,主要用到的是query方法,增加,修改和删除都是update方法,update方法就不讲了 只要创建ResultSetHandler接口不同的实现类对象就可以得到想要的查询结果, ...

  2. BenUtils组件和DbUtils组件

    BenUtils组件和DbUtils组件 [TOC] 1.BenUtils组件 1.1.简介 程序中对javabean的操作很频繁,所有Apache提供了一套开源api,方便javabean的操作!即 ...

  3. 【Java EE 学习 52】【Spring学习第四天】【Spring与JDBC】【JdbcTemplate创建的三种方式】【Spring事务管理】【事务中使用dbutils则回滚失败!!!??】

    一.JDBC编程特点 静态代码+动态变量=JDBC编程. 静态代码:比如所有的数据库连接池 都实现了DataSource接口,都实现了Connection接口. 动态变量:用户名.密码.连接的数据库. ...

  4. <十六>JDBC_使用 DBUtils 编写通用的DAO

    接口 : DAO<T>.java import java.sql.Connection;import java.sql.SQLException;import java.util.List ...

  5. <十五>JDBC_使用 DBUtils 进行更新、查询操作

    详解待续... DBUtilsTest.java import java.sql.Connection;import java.sql.Date;import java.sql.ResultSet;i ...

  6. DBUtils 笔记

    一.DBUtils介绍  apache 什么是dbutils,它的作用 DBUtils是java编程中的数据库操作实用工具,小巧简单实用. DBUtils封装了对JDBC的操作,简化了JDBC操作.可 ...

  7. python DBUtils.PooledDB 中 maxcached 和 maxconnections

    PooledDB 有这么几个参数 mincached : the initial number of idle connections in the pool (the default of 0 me ...

  8. 【Java EE 学习 17 上】【dbutils和回调函数】

    一.dbutils的核心就是回调函数,可以说如果没有回调函数的思想,dbutils是不可能被开发出来的. 对于dbutils中的QuryRunner类,向该类的query方法提供不同的参数,可以得到不 ...

  9. 【Java EE 学习 16 下】【dbutils的使用方法】

    一.为什么要使用dbutils 使用dbutils可以极大程度的简化代码书写,使得开发进度更快,效率更高 二.dbutils下载地址 http://commons.apache.org/proper/ ...

  10. DBUtils

    DBUtils中核心对象 > QueryRunner类 它提供了操作数据增删改查的方法 query() 执行select语句的 update() 执行insert update delete 语 ...

随机推荐

  1. 关于table表格td里内容是数字而且太长不换行的问题

    <p>table{table-layout:fixed}</p><p>table td{word-wrap:break-word}</p><p&g ...

  2. hdu_1695: GCD 【莫比乌斯反演】

    题目链接 这题求[1,n],[1,m]gcd为k的对数.而且没有顺序. 设F(n)为公约数为n的组数个数 f(n)为最大公约数为n的组数个数 然后在纸上手动验一下F(n)和f(n)的关系,直接套公式就 ...

  3. 扩展entity framework core 实现默认字符串长度,decimal精度,entity自动注册和配置

    报道越短,事情越严重!文章越短,内容越精悍! 文章以efcore 2.0.0-preview2.测试验证通过.其他版本不保证使用,但是思路不会差太远.源代码 目标: 1.实现entity的自动发现和m ...

  4. servlet前台中文参数处理

    @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletExcep ...

  5. 了解Java并学会创建Java项目(一个菜鸟的成长历程)

    计算机语言分类:了解 1)低级语言:更接近于计算机的语言 1.1)机器语言:由0和1组成的 1.2)汇编语言:有一些助记符号2)高级语言:更接近于人的语言 2.1)面向过程的:C... 2.2)面向对 ...

  6. 【SignalR学习系列】5. SignalR WPF程序

    首先创建 WPF Server 端,新建一个 WPF 项目 安装 Nuget 包 替换 MainWindows 的Xaml代码 <Window x:Class="WPFServer.M ...

  7. Spring源码情操陶冶-AbstractApplicationContext#finishBeanFactoryInitialization

    承接前文Spring源码情操陶冶-AbstractApplicationContext#registerListeners 约定web.xml配置的contextClass为默认值XmlWebAppl ...

  8. Maven “Failed to execute goal org.apache.maven.plugins:maven-archetype-plugin:2.4:create...”问题总结

    今天学习Maven的过程中,一直遇到一个问题:用maven指令构建新项目时,一直报错,用的 Maven 3.2 , JDK 6. 构建的命令: 错误信息: 解决方案: 在StackOverFlow上找 ...

  9. Spring AOP With AspectJ

    一.AOP和拦截器 某些情况下,AOP和拦截器包括Filter能够实现同样的功能,一般都是请求即controller层的操作,这三个执行顺序为Filter>Interceptor>AOP, ...

  10. 数据结构与算法--KMP算法查找子字符串

    数据结构与算法--KMP算法查找子字符串 部分内容和图片来自这三篇文章: 这篇文章.这篇文章.还有这篇他们写得非常棒.结合他们的解释和自己的理解,完成了本文. 上一节介绍了暴力法查找子字符串,同时也发 ...