Spring JDBC - Interfejs ResultSetExtractor
Plik org.springframework.jdbc.core.ResultSetExtractorinterfejs jest interfejsem wywołań zwrotnych używanym przez metody zapytań JdbcTemplate. Implementacje tego interfejsu wykonują rzeczywistą pracę polegającą na wyodrębnianiu wyników z zestawu wyników, ale nie trzeba się martwić o obsługę wyjątków.
SQLExceptions zostaną przechwycone i obsługiwane przez wywołujący JdbcTemplate. Ten interfejs jest używany głównie w samej strukturze JDBC. RowMapper jest zwykle prostszym wyborem do przetwarzania zestawu wyników, mapując jeden obiekt wynikowy na wiersz zamiast jednego obiektu wynikowego dla całego zestawu wyników.
Deklaracja interfejsu
Poniżej znajduje się deklaracja interfejsu org.springframework.jdbc.core.ResultSetExtractor -
public interface ResultSetExtractor
Stosowanie
Step 1 - Utwórz obiekt JdbcTemplate przy użyciu skonfigurowanego źródła danych.
Step 2 - Użyj metod obiektu JdbcTemplate do wykonywania operacji na bazie danych podczas analizowania zestawu wyników za pomocą narzędzia ResultSetExtractor.
Przykład
Poniższy przykład pokaże, jak odczytać zapytanie przy użyciu klasy JdbcTemplate i interfejsu ResultSetExtractor. Odczytamy dostępny rekord ucznia w tabeli uczniów.
Składnia
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;
}
Gdzie,
SQL - Wybierz zapytanie, aby przeczytać uczniów.
jdbcTemplateObject - Obiekt StudentJDBCTemplate do odczytu obiektu studenta z bazy danych.
ResultSetExtractor - obiekt ResultSetExtractor do analizowania obiektu wyników.
Aby zrozumieć wspomniane wyżej koncepcje związane z Spring JDBC, napiszmy przykład, który wybierze zapytanie. Aby napisać nasz przykład, uruchommy działające środowisko Eclipse IDE i wykonaj następujące kroki, aby utworzyć aplikację Spring.
Krok | Opis |
---|---|
1 | Zaktualizuj projekt Studenta utworzony w rozdziale Wiosna JDBC - Pierwsza aplikacja . |
2 | Zaktualizuj konfigurację fasoli i uruchom aplikację, jak wyjaśniono poniżej. |
Poniżej znajduje się zawartość pliku interfejsu obiektu dostępu do danych StudentDAO.java.
package com.tutorialspoint;
import java.util.List;
import javax.sql.DataSource;
public interface StudentDAO {
/**
* This is the method to be used to initialize
* database resources ie. connection.
*/
public void setDataSource(DataSource ds);
/**
* This is the method to be used to list down
* all the records from the Student table.
*/
public List<Student> listStudents();
}
Poniżej znajduje się zawartość Student.java plik.
package com.tutorialspoint;
public class Student {
private Integer age;
private String name;
private Integer id;
public void setAge(Integer age) {
this.age = age;
}
public Integer getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
}
Poniżej znajduje się plik klasy implementacji StudentJDBCTemplate.java dla zdefiniowanego interfejsu DAO StudentDAO.
package com.tutorialspoint;
import java.util.List;
import java.util.ArrayList;
import javax.sql.DataSource;
import org.springframework.jdbc.core.JdbcTemplate;
public class StudentJDBCTemplate implements StudentDAO {
private DataSource dataSource;
private JdbcTemplate jdbcTemplateObject;
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
this.jdbcTemplateObject = new JdbcTemplate(dataSource);
}
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;
}
}
Poniżej znajduje się zawartość MainApp.java plik.
package com.tutorialspoint;
import java.util.List;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context =
new ClassPathXmlApplicationContext("Beans.xml");
StudentJDBCTemplate studentJDBCTemplate =
(StudentJDBCTemplate)context.getBean("studentJDBCTemplate");
List<Student> students = studentJDBCTemplate.listStudents();
for(Student student: students){
System.out.print("ID : " + student.getId() );
System.out.println(", Age : " + student.getAge());
}
}
}
Poniżej znajduje się plik konfiguracyjny Beans.xml.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd ">
<!-- Initialization for data source -->
<bean id = "dataSource"
class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name = "driverClassName" value = "com.mysql.jdbc.Driver"/>
<property name = "url" value = "jdbc:mysql://localhost:3306/TEST"/>
<property name = "username" value = "root"/>
<property name = "password" value = "admin"/>
</bean>
<!-- Definition for studentJDBCTemplate bean -->
<bean id = "studentJDBCTemplate"
class = "com.tutorialspoint.StudentJDBCTemplate">
<property name = "dataSource" ref = "dataSource" />
</bean>
</beans>
Po utworzeniu plików źródłowych i konfiguracyjnych komponentów bean uruchom aplikację. Jeśli wszystko jest w porządku z Twoją aplikacją, wydrukuje następujący komunikat.
ID : 1, Age : 17
ID : 3, Age : 18