PreparedStatementSetter 인터페이스

그만큼 org.springframework.jdbc.core.PreparedStatementSetter인터페이스는 JdbcTemplate 클래스에서 사용하는 일반 콜백 인터페이스 역할을합니다. 이 인터페이스는 동일한 SQL을 사용하는 일괄 처리의 각 업데이트에 대해 JdbcTemplate 클래스에서 제공하는 PreparedStatement에 값을 설정합니다.

구현은 필요한 매개 변수를 설정해야합니다. 자리 표시자가있는 SQL이 이미 제공되었을 것입니다. 이 인터페이스를 PreparedStatementCreator보다 사용하는 것이 더 쉽습니다. JdbcTemplate은 PreparedStatement를 생성하며, 콜백은 매개 변수 값 설정만을 담당합니다.

인터페이스 선언

다음은 org.springframework.jdbc.core.PreparedStatementSetter 인터페이스에 대한 선언입니다.

public interface PreparedStatementSetter

용법

Step 1 − 구성된 데이터 소스를 사용하여 JdbcTemplate 객체를 생성합니다.

Step 2 − JdbcTemplate 객체 메소드를 사용하여 데이터베이스 작업을 수행하고 PreparedStatementSetter 객체를 전달하여 쿼리에서 자리 표시자를 대체합니다.

다음 예제는 JdbcTemplate 클래스와 PreparedStatementSetter 인터페이스를 사용하여 쿼리를 읽는 방법을 보여줍니다. Student Table에서 사용 가능한 학생 기록을 읽습니다.

통사론

final String SQL = "select * from Student where id = ? ";
List <Student> students = jdbcTemplateObject.query(
   SQL, new PreparedStatementSetter() {
   
   public void setValues(PreparedStatement preparedStatement) throws SQLException {
      preparedStatement.setInt(1, id);
   }
},
new StudentMapper());

어디,

  • SQL − 학생을 읽을 쿼리를 선택합니다.

  • jdbcTemplateObject − 데이터베이스에서 학생 객체를 읽기위한 StudentJDBCTemplate 객체.

  • PreparedStatementSetter − 쿼리에서 매개 변수를 설정하기위한 PreparedStatementSetter 객체.

  • StudentMapper − StudentMapper는 가져온 각 레코드를 학생 개체에 매핑하는 RowMapper 개체입니다.

위에서 언급 한 Spring JDBC 관련 개념을 이해하기 위해 쿼리를 선택하는 예제를 작성 해보자. 예제를 작성하기 위해 작동하는 Eclipse IDE를 준비하고 다음 단계를 사용하여 Spring 애플리케이션을 만듭니다.

단계 기술
1 Spring JDBC-First Application 장에서 만든 Student 프로젝트를 업데이트합니다 .
2 Bean 구성을 업데이트하고 아래 설명 된대로 애플리케이션을 실행하십시오.

다음은 데이터 액세스 개체 인터페이스 파일의 내용입니다. 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
      * a record from the Student table corresponding
      * to a passed student id.
   */
   public Student getStudent(Integer id);
}

다음은의 내용입니다 Student.java 파일.

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

다음은의 내용입니다 StudentMapper.java 파일.

package com.tutorialspoint;

import java.sql.ResultSet;
import java.sql.SQLException;
import org.springframework.jdbc.core.RowMapper;

public class StudentMapper implements RowMapper<Student> {
   public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
      Student student = new Student();
      student.setId(rs.getInt("id"));
      student.setName(rs.getString("name"));
      student.setAge(rs.getInt("age"));
      return student;
   }
}

다음은 구현 클래스 파일입니다. StudentJDBCTemplate.java 정의 된 DAO 인터페이스 StudentDAO 용.

package com.tutorialspoint;

import java.util.List;
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 Student getStudent(final Integer id) {
      final String SQL = "select * from Student where id = ? ";
      List <Student> students = jdbcTemplateObject.query(
         SQL, new PreparedStatementSetter() {
		   
         public void setValues(PreparedStatement preparedStatement) throws SQLException {
            preparedStatement.setInt(1, id);
         }
      },
      new StudentMapper());
      return students.get(0);
   }
}

다음은의 내용입니다 MainApp.java 파일.

package com.tutorialspoint;

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");
      
      Student student = studentJDBCTemplate.getStudent(1);
      System.out.print("ID : " + student.getId() );
      System.out.println(", Age : " + student.getAge()); 
   }
}

다음은 구성 파일입니다. 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>

소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.

ID : 1, Age : 17