首页 > 数据库技术 > 详细

dbutils

时间:2015-07-27 02:16:45      阅读:425      评论:0      收藏:0      [点我收藏+]
一、DBUTILS
 
1.QueryRunner的API
         
     
        QueryRunner() //由于创建时没有指定数据源,其下的所有操作都要明确的传入Connection,由于是自己传入的Connection对象,可以在传入的Connection对象上进行事务管理
        update(Connection conn, String sql) 
        update(Connection conn, String sql, Object... params) 
        update(Connection conn, String sql, Object param) 
        query(Connection conn, String sql, ResultSetHandler<T> rsh) 
        query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) 
         
         
        QueryRunner(DataSource ds) //由于创建是指定了数据源,其下的所有操作都不需要传入Connection,由于是由DBUtils帮住我们管理连接,所以所有的语句都在各自的事务当中,不能手动控制事务
        update(String sql) 
        update(String sql, Object... params) 
        update(String sql, Object param) 
        query(String sql, ResultSetHandler<T> rsh) 
        query(String sql, ResultSetHandler<T> rsh, Object... params) 
         
2.ResultSetHandler的实现类  
        //1.ArrayHandler 将查询结果的第一行转换为一个数组对象返回
        Object[] objs = runner.query("select * from account where name=?",new ArrayHandler() , "c");
        System.out.println(objs);
         
        //2.ArrayHandler 将查询结果的第一行转换为一个数组对象返回
        List<Object[]> list = runner.query("select * from account",new ArrayListHandler() );
        System.out.println(list);
         
        //3.BeanHandler,将查询结果的第一行转换为一个JavaBean对象返回
        Account acc = runner.query("select * from account where name=?",new BeanHandler<Account>(Account.class) , "c");
        System.out.println(acc);
         
        //4.BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。
        List<Account> acclist = runner.query("select * from account",new BeanListHandler<Account>(Account.class));
        System.out.println(acclist);
         
        //5.MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。
        Map map = runner.query("select * from account",new MapHandler() );
        System.out.println(map);
         
        //6.MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List
        List<Map<String, Object>> maplist = runner.query("select * from account",new MapListHandler() );
        System.out.println(maplist);
         
        //7.ColumnListHandler:将结果集中某一列的数据存放到List中。
        List<Object> columnList = runner.query("select * from account",new ColumnListHandler(2) );
        System.out.println(columnList);
         
        //8.KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List<Map>),再把这些map再存到一个map里,其key为指定的列。
        Map<Object, Map<String, Object>> keymap = runner.query("select * from account",new KeyedHandler("id") );
        System.out.println(keymap);
         
        //9.ScalarHandler: 单值查询
        //select count(*) from account;
        Long count = (Long)runner.query("select count(*) from account",new ScalarHandler(1) );
        System.out.println(count);
 
3.DBUtils工具类,提供如关闭连接、装载JDBC驱动程序等常规工作的工具类,里面的所有方法都是静态的。

?

dbutils

原文:http://gengzg.iteye.com/blog/2230251

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!