JDBC3

 昨天上课主要修改了ATM机。但也讲了一些东西-----内部类。1.内部类   2.静态内部类    3.局部内部类  4.匿名局部内部类

东西看着不难,但是实际应用时我感觉有点难。修改atm主要修改DAHelper,BankDao这两个类。创建一个借口Wapper,然后把DAHelper修改成泛型,虽然老师说了DAHelper<T>是泛型,但是他没有讲的很清楚,导致我有点懵。上代码

1.借口

public interface Wapper<T> {
	public T wapper(ResultSet set) throws SQLException;
}

 2.DBHelper<T>,我只上一个方法的代码,因为就这个有含量。

public T queryOne(String sql,Wapper<T> wapper,Object... args){//传入三个参数,第二个是实现
		Connection connection=null;                                         //Wapper借口的类
		PreparedStatement state=null;
		ResultSet set= null;
		T account=null;
		
		try {
			connection=getConnection();
			state=connection.prepareStatement(sql);
			
			for (int i = 0; i < args.length; i++) {
				state.setObject(i+1, args[i]);
			}
			
			set=state.executeQuery();
			
			if (set.next()) {
				account=wapper.wapper(set);//调用实现Wapper借口的类的方法wapper(set),返回
				}                                              //一个Account对象
			
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			close(set,connection,state);
		}
		
		return account;
	}

 3.BankDao类

public Account checkAccountByName(String name) {
		String sql="select id,`name`,`password`,money,isActive from bank where `name`=?";
		return helper.queryOne(sql, new UserWapper(), name);//new UserWapper()是实现Wapper的类
	}


public class UserWapper implements Wapper<Account>{//该类有个方法,根据传入的ResultSert返回
                                                                                          //一个Account对象
		@Override
		public Account wapper(ResultSet set) throws SQLException {
			Account account=new Account();
			
			account.setId(set.getInt("id"));
			account.setName(set.getString("name"));
			account.setPassword(set.getString("password"));
			account.setMoney(set.getFloat("money"));
			account.setActive(set.getBoolean("isActive"));
			
			return account;
		}
		
	}

	
 

 最后上图

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值