博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java使用apache的开源数据处理框架commons-dbutils完成查询结果集的各种处理输出(8种方式)...
阅读量:4624 次
发布时间:2019-06-09

本文共 4961 字,大约阅读时间需要 16 分钟。

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
> list=qr.query(con, sql,new MapListHandler()); //遍历集合List for(Map
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
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
()); System.out.println(count); } /** * 结果集第五种处理方法,ColumnListHandler * 结果集,指定列的数据,存储到List集合 * List
每个列数据类型不同 * @throws SQLException */ public static void columnListHandler() throws SQLException{ QueryRunner qr=new QueryRunner(); String sql="select * from sort"; //调用方法query,传递结果集实现类 //实现类构造方法中,使用字符串的列名 List list=qr.query(con, sql,new ColumnListHandler("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
result=qr.query(con, sql,new BeanListHandler
(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
type) Sort s=qr.query(con,sql, new BeanHandler
(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
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"); } }}

 

转载于:https://www.cnblogs.com/benjamin77/p/9143725.html

你可能感兴趣的文章
C++学习之字符串
查看>>
图像化列表
查看>>
2014年10月9日——语言基础2
查看>>
How to Create Modifiers Using the API QP_MODIFIERS_PUB.PROCESS_MODIFIERS
查看>>
待飞笔记(第一天 )
查看>>
解惑好文:移动端H5页面高清多屏适配方案
查看>>
traefik添加多证书
查看>>
忽略UserInterfaceState.xcuserstate
查看>>
ReactNative--Flexbox布局
查看>>
java实现读取文件大全
查看>>
[Cordova] 无法显示Alert视窗
查看>>
借助过度区选择阈值
查看>>
评论列表显示及排序,个人中心显示
查看>>
JavaWeb学习笔记总结 目录篇
查看>>
C#根据html生成PDF
查看>>
Neutron SDN 手动实现手册
查看>>
linux下core文件调试方法
查看>>
20个创意404错误页面设计的启示
查看>>
基础训练 芯片测试
查看>>
如何用命令将本地项目上传到git
查看>>