DbUtils之ResultSetHandler的实现类

通过使用queryRunner的查询方法,我们知道其使用了回调机制。

下面就对其中的参数ResultSetHandler 的实现类进行不同的查询。

ResultSetHandler 接口用于处理 java.sql.ResultSet,将数据按要求转换为另一种形式。

ResultSetHandler 接口提供了一个单独的方法:Object handle (java.sql.ResultSet .rs)

1.ArrayHandler

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

eg:

<span style="white-space:pre">	</span>//ArrayHandler:把结果集中的第一行数据转成对象数组。
	@Test
	public void test1() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		Object[] objs = runner.query("select * from account where money>?", new ArrayHandler(),500);
		System.out.println(objs);
	}

2.ArrayListHandler

把结果集中的每一行数据都转成一个对象数组,再存放到List中

<span style="white-space:pre">	</span>//ArrayListHandler:把结果集中的每一行数据都转成一个对象数组,再存放到List中。
	@Test
	public void tes2() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		List<Object[]> list = runner.query("select * from account where money>?", new ArrayListHandler(),500);
		System.out.println(list);
	}

3.BeanHandler

将结果集中的第一行数据封装到一个对应的JavaBean实例中

<span style="white-space:pre">	</span>//BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。
	@Test
	public void tes3() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		Account acc = runner.query("select * from account where money>?", new BeanHandler<Account>(Account.class),500);
		System.out.println(acc);
	}

4.BeanListHandler

将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里

<span style="white-space:pre">	</span>//BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。
	@Test
	public void tes4() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		List<Account>list = runner.query("select * from account where money>?", new BeanListHandler<Account>(Account.class),500);
		System.out.println(list);
	}

5.MapHandler

将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值

<span style="white-space:pre">	</span>//MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。
	@Test
	public void tes5() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		 Map<String, Object> map = runner.query("select * from account where money>?", new MapHandler(),500);
		System.out.println(map);
	}

6.MapListHandler

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

<span style="white-space:pre">	</span>//MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List
	@Test
	public void tes6() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		List<Map<String, Object>> list = runner.query("select * from account where money>?", new MapListHandler(),500);
		System.out.println(list);
	}

7.ColumnListHandler

将结果集中某一列的数据存放到List中

<span style="white-space:pre">	</span>//ColumnListHandler:将结果集中某一列的数据存放到List中。
	@Test
	public void tes7() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		List<Object>list = runner.query("select * from account where money>?", new ColumnListHandler(3),500);
		System.out.println(list);
	}

8.KeyedHandler(name)

将结果集中的每一行数据都封装到一个Map里(List<Map>),再把这些map再存到一个map里,其key为指定的列

<span style="white-space:pre">	</span>//KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List<Map>),再把这些map再存到一个map里,其key为指定的列。
	@Test
	public void tes8() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		 Map<Object, Map<String, Object>> map = runner.query("select * from account where money>?", new KeyedHandler("id"),500);
		System.out.println(map);
	}

9.ScalarHandler

获取结果集中第一行数据指定列的值,常用来进行单值查询

<span style="white-space:pre">	</span>//ScalarHandler:获取结果集中第一行数据指定列的值,常用来进行单值查询
	@Test
	public void tes9() throws SQLException{
		QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
		Long count = (Long)runner.query("select count(*) from account",new ScalarHandler());
		System.out.println(count);
	}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值