org.springframework.jdbc.core.ResultSetExtractor
接口是JdbcTemplate
的查询方法使用的回调接口。此接口的实现执行从ResultSet
提取结果的实际工作,不需要担心异常处理,它调用JdbcTemplate
捕获并处理SQLExceptions。 该接口主要用于JDBC框架本身。 RowMapper
通常是ResultSet
处理的简单选择查询,每行映射一个结果对象,而不是整个ResultSet
的一个结果对象。
接口的声明
以下是org.springframework.jdbc.core.ResultSetExtractor
接口的声明 -
public interface ResultSetExtractor
用法
步骤1 - 使用配置的数据源创建一个JdbcTemplate
对象。
步骤2 - 在使用ResultSetExtractor
解析结果集时,使用JdbcTemplate
对象方法进行数据库操作。
实例
以下示例将演示如何使用JdbcTemplate
类和ResultSetExtractor
接口进行读取查询。这里我们将从student
表中读取记录。
语法
public List<Student> listStudents() {
String SQL = "select * from Student";
List <Student> students = jdbcTemplateObject.query(SQL,
new ResultSetExtractor<List<Student>>(){
public List<Student> extractData(
ResultSet rs) throws SQLException, DataAccessException {
List<Student> list=new ArrayList<Student>();
while(rs.next()){
Student student = new Student();
student.setId(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setAge(rs.getInt("age"));
student.setDescription(rs.getString("description"));
student.setImage(rs.getBytes("image"));
list.add(student);
}
return list;
}
});
return students;
}
在上面示例(语法)代码中 -
- SQL - 选择查询语句来来读取学生记录信息。
- jdbcTemplateObject -
StudentJDBCTemplate
对象从数据库中读取Student
对象。 - ResultSetExtractor -
ResultSetExtractor
对象用来解析resultset
对象。