刚才讲了使用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));
}

运行代码



添加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));
}
}

运行代码



添加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());
}

运行代码



注意事项:使用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();
}
}

运行代码



添加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);
}

运行代码



添加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);
}

运行代码



添加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);
}
}

运行代码



添加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);
}

运行代码



添加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);
}

运行代码



到这里,九个Hanlder就介绍完毕了。

最常用的几个:

BeanHandler、BeanListHandler、ColumnListHandler、ScalarHandler。

最新文章

  1. 严重: Null component localEngine:type=JspMonitor,name=jsp,WebModule=//localhost/SpringMVC01,J2EEApplication=none,J2EEServer=none
  2. Python学习感悟
  3. java单例模式实现方式
  4. objective-c UITableview 自定义滑操(原创)
  5. JqueryEasyUI 解决IE下加载时页面错乱的问题 分类: JavaScript JqueryEasyUI 2014-09-20 09:50 545人阅读 评论(1) 收藏
  6. SQL数据库基础(五)
  7. Codeforces Round #242 (Div. 2) C题
  8. HALCON基础知识
  9. template和templateUrl区别与联系
  10. favicon.ico显示,favicon显示,favicon图标显示
  11. Mybatis之ResultMap一个简短的引论,关联对象
  12. HDU ACM 1068 最大独立集
  13. js 将php生成的time()类型时间戳转化成具体date格式的日期
  14. Redis在centos6.4上的最详细图文安装教程
  15. 发现了一个比较有意思的url参数
  16. lombok学习
  17. Android开发技术周报176学习记录
  18. Bugku-CTF之输入密码查看flag
  19. MongoDB ReplacaSet &amp; Sharding集群安装 配置 和 非集群情况的安装 配置 -摘自网络
  20. Java学习笔记:具体解释传值和传引用

热门文章

  1. 网页学习:day1
  2. Python学习2——Python单行注释、整段注释使用方法
  3. 《ElasticSearch6.x实战教程》之实战ELK日志分析系统、多数据源同步
  4. vue教程(四)--其他实用用法补充
  5. Java后台处理框架之struts2学习总结
  6. shiro解析ini文件
  7. Git/Github使用方法小记
  8. 基于 Autojs 的 APP、小程序自动化测试 SDK
  9. SpringMVC项目案例之---数据的获取与显示
  10. Java连载14-补码简介&amp;浮点型整数