首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

运用spring的jdbcTemplate-SimpleJdbcTemplate的使用

2012-09-21 
使用spring的jdbcTemplate-----SimpleJdbcTemplate的使用?1,用简单的JDBC模板更新数据库?传统的JdbcTempla

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

?

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;}}

?

热点排行