package demo;
/*
* QueryRunner数据查询操作;
* 调用QueryRunner类方法query(Connection con,String sql,ResultSetHandler r,Oberct...params))
* ResultSetHandler r 结果集的处理方式,传递ResultSetHandler接口实现类
* Object...params SQL语句中的?占位符
*
* 注意:query方法返回值,返回的是T 泛型,具体返回值类型,跟随结果集处理方式变化
*/ import java.util.List;
import java.util.Map;
import java.sql.Connection;
import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayHandler;
import org.apache.commons.dbutils.handlers.ArrayListHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ColumnListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler; import domain.Sort;
import jdbcutil.JDBCUtilsConfig; public class QueryRunnerDemo1{
private static Connection con=JDBCUtilsConfig.getConnection();
public static void main(String[] args) throws SQLException {
//arrayHandler();
//arrayListHandler();
//beanHandler();
//beanListHandler()
//columnListHandler();
//scalarHandler();
//mapHandler();
mapListHandler();
} /**
* 结果集第八种处理方法,MapListHandler
* 将结果集每一行存储到Map集合,键:列明,值:数据
* Map集合过多,存储到List集合
* @throws SQLException
*/
public static void mapListHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select * from sort";
//调用方法query,传递结果集实现类MapListHandler
List<Map<String, Object>> list=qr.query(con, sql,new MapListHandler());
//遍历集合List
for(Map<String,Object> map:list){
for(String key:map.keySet()){
System.out.print(key+"....."+map.get(key)+"\t");
}
System.out.println();
} } /**
* 结果集的第七种处理方法,MapHandler
* 将结果集第一行数据,封装到Map集合中
* Map<键,值> 键:列名 值:这列的数据
* @throws SQLException
*/
public static void mapHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select * from sort";
//调用方法query,传递结果集实现类MapHandler
//返回值:Map集合,Map接口实现类,泛型
Map<String,Object > map=qr.query(con, sql,new MapHandler());
for(String key:map.keySet()){
System.out.println(key+"....."+map.get(key));
}
} /**
* 结果集第六种处理方法,ScalarHandler
* 对于查询后,只有1个结果
* @throws SQLException
*/
public static void scalarHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select count(*) from sort";
//调用方法query,传递结果集处理实现类scalarHandler
Long count=qr.query(con, sql,new ScalarHandler<Long>());
System.out.println(count);
} /**
* 结果集第五种处理方法,ColumnListHandler
* 结果集,指定列的数据,存储到List集合
* List<Object> 每个列数据类型不同
* @throws SQLException
*/
public static void columnListHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select * from sort";
//调用方法query,传递结果集实现类
//实现类构造方法中,使用字符串的列名
List<Object> list=qr.query(con, sql,new ColumnListHandler<Object>("sname"));
for(Object obj:list){
System.out.println(obj);
}
} /**
* 结果集第四种处理方法,BeanListHandler
* 将数据结果集的每一行数据,封装成javaBean对象
* 多个JavaBean对象封装到List集合中
* @throws SQLException
*
*/
public static void beanListHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select * from sort";
//调用方法传递结果集的实现类 BeanListHandler
List<Sort> result=qr.query(con, sql,new BeanListHandler<Sort>(Sort.class));
for(Sort r:result){
System.out.println(r);
}
} /**
* 结果集的第三种处理方法,BeanHandler
* 将结果集的第一行的数据,封装成JavaBean对象 *
* 注意:被封装成数据到JavaBean对象,Sort类必须有空参数构造
*/
public static void beanHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select * from sort where sid=20";
//调用方法,传递结果集实现类BeanHandler
//BeanHandler(Class<T> type)
Sort s=qr.query(con,sql, new BeanHandler<Sort>(Sort.class));
System.out.println(s);
} /**
* 结果集第二种处理方法,ArrayListHandler
* 将结果集的每一行,封装到对象数组中,出现很多对象数据
* 对象数组存储到List集合
* @throws SQLException
*
*/
public static void arrayListHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select * from sort where sid>10";
//调用query方法,结果集处理的参数上,传递实现类ArrayListHandler
//方法返回值 每行是一个对象数据,存储到List List<Object[]> result =qr.query(con, sql,new ArrayListHandler());
//集合的遍历
for(Object[] objs:result){
for(Object obj:objs){
System.out.print(obj+"\t");
}
System.out.println();
} } /**
* 结果集第一种处理方法,ArrayHandler
* 将结果集的第一行存储到对象数组中 Object[]
* @throws SQLException
*/
public static void arrayHandler() throws SQLException{
QueryRunner qr=new QueryRunner();
String sql="select * from sort where sid=10";
//调用方法query执行查询,传递连接对象,SQL语句,结果集处理方式实现类
//返回对象数组
Object[] result=qr.query(con,sql,new ArrayHandler());
System.out.println(result.length);
for(Object obj:result){
System.out.print(obj+"\t");
}
}
}

Java使用apache的开源数据处理框架commons-dbutils完成查询结果集的各种处理输出(8种方式)的更多相关文章

  1. Java使用apache的开源数据处理框架commons-dbutils完成增删改

    主要使用这个开源jar包的QueryRunner类的update方法来完成数据库的增删改操作. package demo; import java.sql.Connection; import jav ...

  2. Apache Shiro 开源权限框架

    在 Web 项目中应用 Apache Shiro 开源权限框架 Apache Shiro 是功能强大并且容易集成的开源权限框架,它能够完成认证.授权.加密.会话管理等功能.认证和授权为权限控制的核心, ...

  3. 【通信框架】Apache的开源通信框架thrift概述

    在阅读的过程中有不论什么问题.欢迎一起交流 邮箱:1494713801@qq.com    QQ:1494713801 一.作用 Thrift("Scalable Cross-Languag ...

  4. java:struts框架2(方法的动态和静态调用,获取Servlet API三种方式(推荐IOC(控制反转)),拦截器,静态代理和动态代理(Spring AOP))

    1.方法的静态和动态调用: struts.xml: <?xml version="1.0" encoding="UTF-8"?> <!DOCT ...

  5. Struts2框架的数据封装一之属性封装(属性封装的第一种方式:对参数进行封装)

    request带着参数来,aciton对其进行处理.在学习action之前,使用的是servlet对request进行处理.request请求时会带有参数,所以我们要对这些参数进行封装. 1. 为什么 ...

  6. Java基础知识强化之IO流笔记44:IO流练习之 复制图片的 4 种方式案例

    1. 复制图片的 4 种方式案例: 分析: 复制数据,如果我们知道用记事本打开并能够读懂,就用字符流,否则用字节流. 通过该原理,我们知道我们应该采用字节流. 而字节流有4种方式,所以做这个题目我们有 ...

  7. Java基础知识强化之IO流笔记43:IO流练习之 复制文本文件的 5 种方式案例

     1. 案例分析: 分析: 复制数据,如果我们知道用记事本打开并能够读懂,就用字符流,否则用字节流. 通过该原理,我们知道我们应该采用字符流更方便一些. 而字符流有5种方式,所以做这个题目我们有5种方 ...

  8. apache、nginx的虚拟域名配置和rewrite配置,以及web缓存的几种方式

    web缓存一般用来缓解数据库压力. 通常有几种方法,文件静态化,缓存服务memcached.redis等. 伪静态,一般指在url上貌似访问静态html页的形式,这样有利于搜索引擎访问到网站页面,实际 ...

  9. Struts2框架的数据封装一之属性封装(属性封装的第二种方式:封装成javaBean)

    Struts2中提供了两类数据封装的方式? 第一种方式:属性驱动(有两种方式:一个对属性,另外一个是将参数封装到javaBean中) B. 在页面上,使用OGNL表达式进行数据封装.(将参数封装到ja ...

随机推荐

  1. url传参及重定向

    成功跳转$this -> success('提示语',跳转路径,返回的数据,时间,发送的 Header 信息)跳转失败$this -> error('提示语',跳转路径,返回的数据,时间, ...

  2. Database returned an invalid datetime value. Are time zone definitions for your database installed?

    在做文章归档的会后,打印结果时报了这个错误 ret = models.Article.objects.filter(user=user).annotate(month=TruncMonth('crea ...

  3. 笔记-python-standard library-17.1 threading

    笔记-python-standard library-17.1 threading 1.      threading source code: Lib/threading.py 本模块构建高级别的线 ...

  4. cakephp中使用 find('count')方法

    对于find('count',array('group'=>'user_id')); Model.php中这样描述: /** * Handles the before/after filter ...

  5. 微服务化的不同阶段 Kubernetes 的不同玩法

    欢迎访问网易云社区,了解更多网易技术产品运营经验. 作为容器集群管理技术竞争的大赢家,Kubernetes已经和微服务紧密联系,采用Kubernetes的企业往往都开始了微服务架构的探索.然而不同企业 ...

  6. Careercup - Microsoft面试题 - 24313662

    2014-05-12 07:27 题目链接 原题: Convert a number to a number 题目:把二进制数转化成四进制数. 解法:四是二的倍数,所以两位变一位就可以了. 代码: / ...

  7. 图说不为人知的IT传奇故事-2-IBM咬不动的胡桃

    此系列文章为“图说不为人知的IT传奇故事”,各位大忙人可以在一分钟甚至几秒内了解把握整个内容,真可谓“大忙人的福利”呀!!希望各位IT界的朋友在钻研技术的同时,也能在文学.历史上有所把握.了解这些故事 ...

  8. IOS开发学习笔记030-xib实现淘宝界面

    使用xib文件实现界面,然后通过模型更新数据. 1.使得控制器继承自UITableViewController 2.创建xib文件,实现界面如下:一个UIImageView,两个lable 3.新建一 ...

  9. Windows网络编程笔记5 -- 其他套接字

    包括红外线套接字(IrSock).IPX/SPX 套接字.NetBIOS 套接字.AppleTalk 套接字.ATM 套接字等.对这些套接字进行简单介绍. 第一.红外线套接字(I r S o c k) ...

  10. 06 JVM 是如何处理异常的

    在 JAVA 中,异常处理的方式主要是抛出异常和捕获异常.这两大要素共同实现程序控制流的非正常转移. 抛出异常可以分为显示和隐式两种.显示抛出异常的主体是应用程序,它指的是在程序中使用 throw 关 ...