动力节点首页 全国咨询热线:400-8080-105

绑定手机号,登录
手机号

验证码

微信登录
手机号登录
手机号

验证码

微信登录与注册
微信扫码登录与注册

扫码关注微信公众号完成登录与注册
手机号登录
首页 > 文章

DBUtils框架的使用(下)

04-13 18:12 1000浏览
举报 T字号
  • 大字
  • 中字
  • 小字

刚才讲了使用QueryRunner插入、修改、更新数据,现在来学习一下使用QueryRunner进行数据库表查询。通过QueryRunner类的query()方法即可完成数据库表的查询操作,但是在查询的时候需要实现ResultSetHandler接口来将结果集封装成对象。可以通过自己实现接口,但很显然,我们应该使用DBUtils工具包提供的实现类来实现封装。在DBUtils框架中,共提供了九个ResultSetHandler的实现类。

  • ArrayHandler:把结果集中的第一行数据转成对象数组。
  • ArrayListHandler:把结果集中的每一行数据都转成一个对象数组,再存放到List中。
  • BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。
  • BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。
  • ColumnListHandler:将结果集中某一列的数据存放到List中。
  • MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。
  • MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List
  • KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List),再把这些map再存到一个map里,其key为指定的key。
  • ScalarHandler:将结果集中的列的信息转换到一个对象中

分别通过案例感受一下。新建测试类ResultSetHandlerTest,然后添加成员变量

private ComboPooledDataSource dataSource = new ComboPooledDataSource();

添加ArrayHandler的测试代码    

@Test
public void testArrayHandler() throws SQLException{
    //ArrayHandler    将结果集的第一行数据存入Object数组
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";

    //数组的每一个元素对应第一行数据的每一列
    Object[] objects = queryRunner.query(sql, new ArrayHandler());
    System.out.println(Arrays.toString(objects));
}

运行代码,结果为:

[1,aaa,900.0]

添加ArrayListHandler测试代码

@Test
public void testArrayListHandler() throws SQLException{
    //ArrayListHandler    将结果集的每一行数据存入Object数组,然后存入List
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";
    List<Object[]> list = queryRunner.query(sql, new ArrayListHandler());
        
    for(Object[] objects : list){
        System.out.println(Arrays.toString(objects));
    }
}

 运行代码结果如下:

[1,aaa,900.0]
[4,ddd,1000.0]
[5,fff,2000.0]

添加BeanHandler测试代码

@Test
public void testBeanHandler() throws SQLException{
    //BeanHandler    将结果集的第一行数据封装到JavaBean对象中
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";
        
    //传入Account.class参数是为了在方法中通过反射构造Account对象实例
    Account account = queryRunner.query(sql, new BeanHandler<Account>(Account.class));
    System.out.println(account.getId());
    System.out.println(account.getName());
    System.out.println(account.getMoney());
}

运行代码运行结果如下:

1
aaa
900.0

注意事项:使用BeanHandler,表列名必须与Bean类的属性名称一致。

添加BeanListHandler测试代码    

@Test
public void testBeanListHandler() throws SQLException{
    //BeanListHandler    将结果集每一条数据都封装到JavaBean对象,再存入List
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";
    List<Account> list = queryRunner.query(sql, new BeanListHandler<Account>(Account.class));
        
    for(Account account : list){
        System.out.print(account.getId() + "\t");
        System.out.print(account.getName() + "\t");
        System.out.print(account.getMoney());
        System.out.println();
    }
}
    

运行代码运行结果如下:

1  aaa   900.0
4  ddd   1000.0
5  fff   2000.0

添加ColumnListHandler测试代码

@Test
public void testColumnListHandler() throws SQLException{
    //ColumnListHandler获得结果集的某一列
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";
        
    //泛型为什么写Object因为每列的类型都不一样
    List<Object> list = queryRunner.query(sql, new ColumnListHandler("name"));
    System.out.println(list);
}

运行代码运行结果如下:

[aaa,ddd,fff]

添加MapHandler测试代码

@Test
public void testMapHandler() throws SQLException{
    //MapHandler将结果集中的第一行数据封装到Map集合,key是列名,value是数据值
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";
    Map<String, Object> map = queryRunner.query(sql, new MapHandler());
    System.out.println(map);
}

运行代码运行结果如下:

{id=1,name=aaa,money=900.0}

添加MapListHandler测试代码

@Test
public void testMapListHandler() throws SQLException {
    // MapHandler 将结果集中的每一行数据封装到Map集合,key是列名,value是数据值,再将Map对象存入List
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";
    List<Map<String,Object>> list = queryRunner.query(sql, new MapListHandler());
        
    for(Map<String,Object> map : list){
            System.out.println(map);
    }
}

运行代码,运行结果如下:

{id=1,name=aaa,money=900.0}
{id=4,name=ddd,money=1000.0}
{id=5,name=fff,money=2000.0}

添加KeyedHandler测试代码

@Test
public void testKeyedHandler() throws SQLException {
    // KeyedHandler将结果集中的每一行数据都封装到Map里,再将Map存入一个Map里,key可以指定为任意列
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select * from account";
    Map<Object, Map<String,Object>> map = queryRunner.query(sql, new KeyedHandler("name"));
        
    System.out.println(map);
}   

运行代码

{fff={id=5,name=fff,money=2000.0},aaa={id=1,name=aaa,money=900.0},ddd={id=4,name=ddd,money=1000.0}}

添加ScalarHandler测试代码

@Test
public void testScalarHandler() throws SQLException{
    //ScalarHandler通常保存只有一行一列的结果数据
    QueryRunner queryRunner = new QueryRunner(dataSource);
    String sql = "select count(*) from account";
    long count = (Long) queryRunner.query(sql, new ScalarHandler(1));
    System.out.println(count);
}

运行代码,结果为:

3

到这里,九个Hanlder就介绍完毕了。最常用的几个:BeanHandler、BeanListHandler、ColumnListHandler、ScalarHandler。

1人推荐
共同学习,写下你的评论
0条评论
代码小兵221
程序员代码小兵221

6篇文章贡献46012字

作者相关文章更多>

推荐相关文章更多>

浅谈数据库索引的原理

代码小兵69606-03 17:02

MySQL的索引为什么使用B+Tree

代码小兵69606-07 17:03

浅谈JDBC是什么

代码小兵12406-08 16:31

MySQL索引的优化

代码小兵12406-08 16:40

JDBC连接数据库

代码小兵12406-08 17:37

发评论

举报

0/150

取消