使用spring的jdbcTemplate-----SimpleJdbcTemplate的使用

本文介绍Spring框架中的SimpleJdbcTemplate,简化了JDBC操作。通过示例展示了如何利用SimpleJdbcTemplate进行数据库更新和查询操作,包括单条记录和批量处理,并介绍了ParameterizedRowMapper及其便利实现ParameterizedBeanPropertyRowMapper。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

1,用简单的JDBC模板更新数据库

 

传统的JdbcTemplate的许多方法都需要将语句参数作为对象数组进行传递,在SimpleJdbcTemplate中,可将其作为可变长度参

数进行传递,这样免去了将它们包装在一个数组中的麻烦,使用SimpletJdbcTemplate可以直接实例化,也可以扩展

SimpleJdbcDaoSuppport类来获取它的实例,

 

public class JdbcUserDao extends SimpleJdbcDaoSupport implements UserDao{

	public void insert(User user){

		String sql = "insert into user values (?,?)";
		this.getSimpleJdbcTemplate().update(sql,user.getUsername(),user.getPassword());
	}
}

 

SimpleJdbcTemplate提供了一个便利的批处理方法,指定一个SQL语句,再以List<Object[]>的形式指定一批参数,这样就不用

实现BatchPreparedStatementSetter接口了.

 

public class JdbcUserDao extends SimpleJdbcDaoSupport implements UserDao{

	public void insert(List<User> user){

		String sql ="insert into user values(?,?)";
		
		List<Object[]> parameters = new ArrayList<Objcet[]>();
		for(User u: user){

			parameters.add(new Object[]{u.getUsername(),u.getPassword()});
		}
		this.getSimpleJdbcTemplate().batchUpdate(sql,paramters);
	}
}

 

 

2,用简单的JDBC模板查询数据库

 

再实现RowMaper接口时。可以使用java.lang.Object.ParameterizedRowMapper子接口,它接受一个类型参数作为mapRow()方法的返回类型。

 

public class UserRowMapper implements ParamterizedRowMapper<User>{

	public User mapRow(ResultSet rs,int rowNum)throws SQLException{

		User user  = new User();
		user.setUsername(rs.getString("username"));
		user.setPassword(rs.getString("password"));
		return user;
	}
}

 

 

将SimpleJdbcTemplate与ParameterizedRowMapper结合起来使用,可以免去强制类型转换返回结果类型的麻烦,对于queryForObjcet()方法而言,返回类型由ParameterizedRowMapper对象的类型参数决定的,

 

public class JdbcUserDao extends SimpleJdbcDaoSupport implements UserDao{
	
	public User findByUserId(int id){

		String sql ="select *from user where id=?":
		
		User user = this.getSimpleJdbcTemplate().queryForObject(sql,new UserRowMapper(),id);
		return user;
	}
}

 

 

在spring2.5中叶提供了一个便利的ParameterizedRowMapper实现,---ParameterizedBeanPropertyRowMapper,它可以自动将结果集中的一行映射到指定类的新实例上

 

public class JdbcUserDao extends SimleJdbcDaoSupport implements UserDao{

	public List<User> findAll(){

		String sql ="select *from user ";

		List<User> users = this.getSimpleJdbcTemplate().query				

(sql,ParameterizedBeanPropertyRowMapper.newInstance(User.class));
		return users;
	}
}

 

在通过SimpleJdbcTemplate查询单个值时,queryForObject()方法的返回类型由class参数(如,String.class)决定,因此,需要手工执行类型强制转换,

 

public class JdbcUserDao extends SimpleJdbcDaoSupport implements UserDao{

	public String getUsername(int id){

		String sql ="select username from user where id= ?";

		String username = this.getSimpleJdbcTemplate().queryForObject(sql,String.class,id);
		return username;
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值