dbutils

一、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驱动程序等常规工作的工具类,里面的所有方法都是静态的。

转载于:https://my.oschina.net/abian/blog/163218

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值