我们做过的很多项目中都会使用spring的JdbcTemplate进行结果集的查询操作,以前在使用的时候一直都是“拿来主义”,功能实现了就OK了,没有深究什么内容,特别是查询接口的回调内容方法,没有过多的研究过细节内容。最近一次使用JdbcTemplate进行查询操作,发现了一些有规律的内容,所以就深入学习了一下。和大家一起探讨一下:
?
对于spring的JdbcTemplate进行结果集查询操作,spring给我们开发的是一系列的query方法,这些查询的方法中回调的接口主有三种:ResultSetExtractor,RowCallbackHandler,RowMapper,这个内容有图有真相:
?
但是这三种回调接口具体的用法和区别,我们一起来看一下:
场景设定,数据库中存在T_USER表,表中存在多条数据,需要将是表中数据映射到User对象上
? ? ? ?1、org.springframework.jdbc.core.ResultSetExtractor
? ? ?ResultSetExtractor接口中定义的方法如下:
? ? ?
public interface ResultSetExtractor { Object extractData(ResultSet rs) throws SQLException, DataAccessException; }
?
? ? ? ? 如果使用ResultSetExtractor接口作为回调方法,查询方式如下:
??
List<User> userList = (List<User>)jdbcDao.getJdbcTemplate(). query("select * from T_USER", new ResultSetExtractor() { @Override public Object extractData(ResultSet rs) throws SQLException, DataAccessException { List<User> userList = new ArrayList<User>(); while (rs.next()) { User user = new User(); user.setId(rs.getInt("N_ID")); user.setName(rs.getString("C_NAME")); userList.add(user); } return userList; } });
?
? ? ? ? 2、org.springframework.jdbc.core.RowCallbackHandler
? ? ? ? ? ? ? RowCallbackHandler接口中定义的方法如下:
public interface RowCallbackHandler { void processRow(ResultSet rs) throws SQLException; }
?
? ? ? ? 如果使用RowCallbackHandler接口作为回调方法,查询方式如下:
final List<User> userList = new ArrayList<User>(); jdbcDao.getJdbcTemplate().query("select * from T_USER", new RowCallbackHandler(){ @Override public void processRow(ResultSet rs) throws SQLException { User user = new User(); user.setId(rs.getInt("N_ID")); user.setName(rs.getString("C_NAME")); userList.add(user); } });
? ? ? ? ?3、o