数据库开发四:JDBC数据库开发进阶三(commons-dbutils结果集处理器介绍)

出处:https://www.cnblogs.com/gdwkong/p/7633250.html
 common-dbutils.jar是Apache组织提供的一个对JDBC进行简单封装的开源工具类库,使用它能够简化JDBC应用程序的开发,同时也不会影响程序的性能。

1、QueryRunner类

①update方法:

int update(String sql,Object...params) -->可执行增删改语句
int update(Connection con,String sql,Object...params)-->需要调用者提供Connection,这说明本方法不再管理Connection。支持事务。

②query方法:

T query(String sql,ResultSetHandler rsh,Object...params)-->可执行查询
    它会先得到ResultSet,然后调用rsh的handle()把rs转换成需要的类型。
T query(Connection con,String sql,ResultSetHandler rsh,Object...params);支持事务。

2、ResultSetHandler接口:

BeanHandler(单行)-->构造器需要一个Class类型参数,用来把一行结果转换成指定类型的javabean对象。
BeanListHandler(多行)-->构造器也是需要一个Class类型的参数,用来把一行结果集转换成一个javabean,那么多行就是转换成List对象,一堆javabean
MapHandler(单行)-->把一行结果集转换成Map对象
    一行记录:
    sid     sname   age   gender
    1001     zs         99     male
    一个Map:
    {sid:1001, sname:zs, age:99, gender:male}
MapListHandler(多行) -->把一行记录转换成一个Map,多行就是多个Map,即List<Map>.
ScalarHandler(单行单列) -->通常用与“SELECT COUNT(*) FROM t_stu;”语句,结果集是单行单列的,它返回一个Object。

3示例

import cn.itcast.jdbc.JdbcUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.*;
import org.junit.Test;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

public class Demo3 {
    @Test
    public void fun1() throws SQLException {
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "INSERT INTO t_stu VALUES(?,?,?,?)";
        Object[] params = {1002,"lisi",99,"female"};
        qr.update(sql,params);
    }
    @Test
    public void fun2() throws SQLException {
        //创建QueryRunner,提供数据库连接池对象
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        //给出sql模板
        String sql = "SELECT * FROM t_stu WHERE sid=?";
        //给出参数
        Object[] params = {1002};
        //执行query()方法,需要给出集处理器,即 ResultSetHandler的实现类对象
        //我们需要给的是BeanHandler,它实现了ResultSetHandler
        //它需要一个类型,然后它会把rs中的数据封装到指定类型的javabean对象中,然后返回javabean对象
        Stu stu = qr.query(sql,new BeanHandler<Stu>(Stu.class),params);
        System.out.println(stu);
    }
    //BeanListHandler的应用,它是多行处理器
    //每行对象一个Stu对象
    @Test
    public void fun3() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT * FROM t_stu";
        List<Stu> stuList = qr.query(sql,new BeanListHandler<Stu>(Stu.class));
        System.out.println(stuList);
    }

    //MapHandler的应用,它是单行处理器,把一行转换成一个Map对象
    @Test
    public void fun4() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT * FROM t_stu WHERE sid=?";
        Object[] params = {1001};
        Map map = qr.query(sql,new MapHandler(),params);
        System.out.println(map);
    }

    //MapListHandler,它是多行处理器,把每行都转换成一个Map,即List<Map>
    @Test
    public void fun5() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT * FROM t_stu ";
        List<Map<String,Object>> mapList = qr.query(sql,new MapListHandler());
        System.out.println(mapList);
    }@Test
    //ScalarHandler,它是单行单列时使用,最为合适。
    public void fun6() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT COUNT(*) FROM t_stu ";
        Number cnt = (Number) qr.query(sql,new ScalarHandler());
        long c = cnt.longValue();
        System.out.println(c);
    }
}
import cn.itcast.jdbc.JdbcUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.*;
import org.junit.Test;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

public class Demo3 {
    @Test
    public void fun1() throws SQLException {
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "INSERT INTO t_stu VALUES(?,?,?,?)";
        Object[] params = {1002,"lisi",99,"female"};
        qr.update(sql,params);
    }
    @Test
    public void fun2() throws SQLException {
        //创建QueryRunner,提供数据库连接池对象
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        //给出sql模板
        String sql = "SELECT * FROM t_stu WHERE sid=?";
        //给出参数
        Object[] params = {1002};
        //执行query()方法,需要给出集处理器,即 ResultSetHandler的实现类对象
        //我们需要给的是BeanHandler,它实现了ResultSetHandler
        //它需要一个类型,然后它会把rs中的数据封装到指定类型的javabean对象中,然后返回javabean对象
        Stu stu = qr.query(sql,new BeanHandler<Stu>(Stu.class),params);
        System.out.println(stu);
    }
    //BeanListHandler的应用,它是多行处理器
    //每行对象一个Stu对象
    @Test
    public void fun3() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT * FROM t_stu";
        List<Stu> stuList = qr.query(sql,new BeanListHandler<Stu>(Stu.class));
        System.out.println(stuList);
    }

    //MapHandler的应用,它是单行处理器,把一行转换成一个Map对象
    @Test
    public void fun4() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT * FROM t_stu WHERE sid=?";
        Object[] params = {1001};
        Map map = qr.query(sql,new MapHandler(),params);
        System.out.println(map);
    }

    //MapListHandler,它是多行处理器,把每行都转换成一个Map,即List<Map>
    @Test
    public void fun5() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT * FROM t_stu ";
        List<Map<String,Object>> mapList = qr.query(sql,new MapListHandler());
        System.out.println(mapList);
    }@Test
    //ScalarHandler,它是单行单列时使用,最为合适。
    public void fun6() throws Exception{
        QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource());
        String sql = "SELECT COUNT(*) FROM t_stu ";
        Number cnt = (Number) qr.query(sql,new ScalarHandler());
        long c = cnt.longValue();
        System.out.println(c);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Javascript & jQuery &Ajax&JSON · jquery-1.7.2.js · jquery-1.7.2.min.js · jQuery插件 · EasyUI+v1.3.4官方API中文版 · EasyUI+v1.3.4官方API中文版.rar · jackson-src-1.7.1.zip · ext-3.0.0.zip · google-gson-2.2.4-release.zip apache-commons框架 · commons-validator-1.3.1-src.zip · commons-lang3-3.2.1-src.zip   · commons-fileupload-1.2.1-src.zip   · commons-dbutils-1.3-bin.zip   · commons-pool-1.5.5-bin.zip   · commons-io-2.0-bin.zip   · commons-lang-2.5-src.zip   · commons-logging-1.1.1-bin.zip   · commons-io-2.0-src.zip   · commons-lang3-3.2.1-bin.zip   · commons-lang-2.5-bin.zip   · commons-dbutils-1.3-src.zip   · commons-pool-1.5.5-src.zip   · commons-validator-1.3.1.zip   · commons-logging-1.1.1-src.zip   · commons-dbcp-1.4-src.zip   · commons-fileupload-1.2.1-bin.zip   · commons-codec-1.4-bin.zip   · commons-dbcp-1.4-bin.zip   · commons-collections-3.2.1-src.zip   · commons-codec-1.4-src.zip   · commons-beanutils-1.8.0-bin.zip   · commons-beanutils-1.8.0-src.zip   · commons-collections-3.2.1-bin.zip SSH框架   · struts-menu-2.4.3.zip   · spring-modules-0.9-with-dependencies.zip   · spring-framework-3.1.0.CI-1163-dependencies.zip   · spring-framework-2.5.6.SEC01-with-dependencies.zip   · struts-menu-2.4.3-src.zip   · struts-2.3.15.3-all.zip   · spring-framework-4.0.0.RELEASE-dist.zip   · struts-2.3.4-all.zip   · struts-1.3.8-all.zip   · spring-framework-3.1.1.RELEASE-with-docs.zip   · struts2-2.2.1-all.zip · struts-2.1.8.1-all.zip  · hibernate-distribution-3.6.0.Final-dist.zip   · hibernate-distribution-3.5.1-Final-dist.zip   · hibernate-release-4.2.4.Final.zip spring-data-jpa(1.4.2.RELEASE)   · spring-data-jpa-1.4.2.RELEASE-sources.jar   · spring-data-jpa-1.4.2.RELEASE-javadoc.jar   · spring-data-jpa-1.4.2.RELEASE.jar  · spring-data-jpa-reference.pdf spring-data-commons  · spring-data-commons-1.6.2.RELEASE-sources.jar · spring-data-commons-1.6.2.RELEASE.jar   · spring-data-commons-1.6.2.RELEASE-javadoc.jar shiro   · shiro所有相关jar包   · shiro-root-1.2.2-source-release.zip spring-security   · spring-security-3.1.0.M1.zip   · spring-security-2.0.5.zip 工作流   · jbpm-4.3.zip   · jbpm-4.4.zip   · jbpm-jpdl-suite-3.2.3.zip   · activiti-5.15.1.zip 其它   · spring-modules-0.9.zip   · poi-src-3.5-FINAL-20090928.zip   · poi-bin-3.5-FINAL-20090928.zip   · slf4j-1.6.1.zip   · pinyin4j-2.5.0.zip   · ognl.zip   · mysql-connector-java-5.1.7.zip   · joda-time-2.3-dist.zip   · jfreechart-1.0.13-javadocs.zip   · jfreechart-1.0.13.zip   · jdom-1.1.zip   · javamail-1_4_1.zip   · jakarta-taglibs-standard-1.1.2-src.zip   · jakarta-taglibs-standard-1.1.2.zip   · jaf-1_1_1.zip   · hibernate-validator-5.0.0.CR2-dist.zip   · guice-1.0-src.zip   · guice-1.0.zip   · displaytag-1.2-bin.zip   · displaytag-1.2-src.zip   · cewolf-1.1.4.zip   · cewolf-1.0-bin-src.zip   · c3p0-0.9.1.2.src.zip   · c3p0-0.9.1.2.bin.zip   · apache-log4j-1.2.15.zip   · xwork2-2.1.rar   · dom4j-1.6.1.rar   · elecfans.com-XPath.rar   · xwork-assembly-2.1.6-all.zip   · quartz-2.2.1-distribution.tar.gz   · xloadtree_zh_cn.zip   · xdoclet-src-1.2.3.zip   · xdoclet-bin-1.2.3.zip   · xfire-distribution-1.2.6.zip   · xdoclet-lib-1.2.3.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值