通过使用queryRunner的查询方法,我们知道其使用了回调机制。
下面就对其中的参数ResultSetHandler 的实现类进行不同的查询。
ResultSetHandler 接口用于处理 java.sql.ResultSet,将数据按要求转换为另一种形式。
ResultSetHandler 接口提供了一个单独的方法:Object handle (java.sql.ResultSet .rs)
1.ArrayHandler
把结果集中的第一行数据转成对象数组
eg:
//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中
//ArrayListHandler:把结果集中的每一行数据都转成一个对象数组,再存放到List中。
@Test
public void tes2() throws SQLException{
QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
List
3.BeanHandler
将结果集中的第一行数据封装到一个对应的JavaBean实例中
//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.class),500);
System.out.println(acc);
}
4.BeanListHandler
将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里
//BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。
@Test
public void tes4() throws SQLException{
QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
Listlist = runner.query("select * from account where money>?", new BeanListHandler(Account.class),500);
System.out.println(list);
}
5.MapHandler
将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值
//MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。
@Test
public void tes5() throws SQLException{
QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
Map map = runner.query("select * from account where money>?", new MapHandler(),500);
System.out.println(map);
}
6.MapListHandler
将结果集中的每一行数据都封装到一个Map里,然后再存放到List
//MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List
@Test
public void tes6() throws SQLException{
QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
List
7.ColumnListHandler
将结果集中某一列的数据存放到List中
//ColumnListHandler:将结果集中某一列的数据存放到List中。
@Test
public void tes7() throws SQLException{
QueryRunner runner = new QueryRunner(new ComboPooledDataSource());
List
8.KeyedHandler(name)
将结果集中的每一行数据都封装到一个Map里(List
//KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List
9.ScalarHandler
获取结果集中第一行数据指定列的值,常用来进行单值查询
//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);
}