본문 바로가기

Spring

[Spring] JDBC




스프링과 JDBC

 

: 스프링은 JDBC 비롯하여 ORM프레임워크(myBatis, 하이버네이트, JPA(Java Persistence API)) 지원한다

 

: 스프링의 목표는 인터페이스에 의한 개발인데 DAO 데이터베이스에서 데이터를 읽거나 쓰는 수단을 제공하기 위해 존재하며, 반드시 인터페이스를 통해 외부에 제공돼야 한다.

서비스 객체는 인터페이스를 통해서 DAO 접근한다 

서비스 객체를 특정 데이터 액세스 구현체에 결합시키지 않음으로써 테스트를 용이하게 한다

DAO인터페이스는 DAO구현과 서비스 객체 사이에서 느슨한 결합이 유지될  있게 한다

 

 

서비스 객체         → DAO 인터페이스

UserInsertAction         UserDAO                

                           ↑

                      DAO 구현 객체

                        UserDAOImpl

 

 

: 스프링은 데이터베이스 연동을 위한 템플릿 클래스를 제공함으로써

Connection, Statement(PreparedStatement), ResultSet등을 생성하고 처리한 다음 close(반환)하는 JDBC 중복된 코드를 줄일  있다

 

: JDBC 무조건 SQLException 예외만 발생하므로 정확히 Connection에서 발생했는지 아니면 Statement에서 발생했는지 따져봐야한다. JdbcTemplate클래스는 SQLException 발생하면 스프링이 제공하는 예외 클래스중 알맞는 것으로 변환해서 발생한다.

스프링은 JDBC보다 다양한 예외 계층을 제공하고 어떤 퍼시스턴스 솔루션과도 연관성을 갖지 않는다 

스프링을 사용하면 퍼시스턴스 기술과 관계없이 일관성있게 예외를 발생시킬  있다

 

: 스프링의 DataAccessException 비검사형 예외(try~catch블럭을 사용하지 않아도 컴파일이 되는 예외)로서 반드시 잡아서 처리할 필요가 없다

 

: 스프링이 제공하는 DataSource 설정하는 3가지 방법

 

1. 커넥션풀을 이용한 DataSource 설정

스프링이 직접적으로 커넥션풀을 제공하진 않지만 DBCP(Jakarta Commons Database Connection Pool) API 같은 커넥션  라이브러리를 이용

DBCP에는 풀링 기능을 제공하는 다양한 데이터 소스가 포함되 있지만 BasicDataSource 가장 많이 사용된다

 

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">

     <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />

     <property name="url" value="jdbc:oracle:thin:@localhost:1521:xe" />

     <property name="username" value="java8" />

     <property name="password" value="itbank" />

     <property name="initialSize" value="5" /> → 해당 풀이 시작될  생성할 커넥션 , 0 무제한

     <property name="maxActive" value="10" /> → 해당 풀에서 동시에 제공할  있는 최대 커넥션 , 0 무제한

</bean>

 

 

2. JNDI 이용한 DataSource 설정

WebLogic이나 JBoss 같은 JEE 어플리케이션 서버를 사용할 경우

톰캣이난 Resin등의  컨테이너를 사용할 경우

 

<jee:jndi-lookup id="dataSource" jndi-name="oracle" resource-ref="true" />

<jee:jndi-lookup>태그를 이용 - 스프링2.0부터 지원

jndi-name 프로퍼티는 JDNI 있는 리소스의 이름을 지정한다

jndi-name프로퍼티만 지정된 경우에는 데이터소스는 지정된 jndi-name 그대로 이용해서 검색한다

자바 애플리케이션 서버에서 가동되는 경우에는  resource-ref=true이면 jndi-name값의 앞에 "java:comp/env" 붙은 이름을 사용한다

 

<jee:jndi-lookup>태그를 사용하지 않고 JndiObjectFactoryBean클래스를 이용할  있다

 

 

3. DriverManager 이용한 DataSource 설정

: 스프링에 설정할  있는 가장 단순한 데이터 소스는 JDBC드라이버를 통해 정의된 것이다

 

- DriverManagerDataSource

애플리케이션이 커넥션을 요청할 때마다 새로운 커넥션을 반환한다

DBCP BasicDataSource와는 달리 커넥션은 풀링되지 않는다

멀티스레드에서도 동작은 하지만 커넥션이 필요할 때마다 새로 커넥션을 생성하므로 심각한 성능 저하를 유발한다.

 

- SingleConnectionDataSource

커넥션을 요청하면 항상 동일한 커넥션을 반환한다

커넥션 풀링 기능은 없지만 오직 하나의 커넥션만을 풀링하는 데이터소스

사용할  있는 커넥션이 오직 하나뿐이라서 멀티스레드 애플리케이션에서는 제대로 동작하지 않을 것이다

 

: 스프링의 JDBC 프레임워크는 자원관리와 예외 처리를 대신 해주므로 JDBC코드가 훨씬 간결해진다

스프링은 단순 반복적인 데이터 액세스 코드를 템플릿 클래스 뒤로 추상화해 숨긴다

 

1. JdbcTemplate

스프링의 가장 기본적인 JDBC 템플릿

색인된 파라미터(indexed parameter)기반의 쿼리를 통해 데이터베이스를 쉽게 액세스하는 기능을 제공

 

2. NamedParameterJdbcTemplate

SQL 값들을 색인된 파라미터 대신 명명된 파라미터(named parameter) 바인딩하여 쿼리를 수행할  있게 해준다 

 

3. SimpleJdbcTemplate

자바 5 제공하는 오토박싱,제네릭스, 가변 파라미터(varargs)등을 활용

스프링 2.5에서는 NamedParameterJdbcTemplate 명명된 파라미터기능은  SimpleJdbcTemplate 합쳐졌다

 

: SimpleJdbcTemplate 이용한 데이터 액세스

모든 SimpleJdbcTemplate DataSource 있어야 작동한다

 

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.simple.SimpleJdbcTemplate">

     <constructor-arg ref="dataSource" />

</bean>

 

 

: jdbcTemplate DAO 와이어링

 

public class UserDAOImpl implements UserDAO {

     private JdbcTemplate jdbcTemplate;

 

     public void setJdbcTemplate(JdbcTemplate jdbcTemplate){

          this.jdbcTemplate = jdbcTemplate;

     }

}

 

<bean id="userDao" class="user.dao.UserDAOImpl">

     <property name="jdbcTemplate" ref="jdbcTemplate" />

</bean>

 

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">

     <constructor-arg ref="dataSource" />

</bean>

---------------------------------------------------

SimpleJdbcTemplate 빈을  DAO 클래스의 프로퍼티에 연결해 줘야 했다

그런데 여러개의 DAO클래스를 작성하는 경우라면 많은 중복코드가 발생한다

모든 DAO 객체에 대해 SimpleJdbcTemplate 프로퍼티를 갖는 공통부모클래스를 작성한다

 

 

스프링이 제공하는 기반클래스

JdbcTemplate - JdbcDaoSupport

NamedParameterJdbcTemplate - NamedParameterJdbcDaoSupport

 

 

 

<bean id="memberDao" class="com.dao.jdbcMemberDAO">

     <property name="dataSource" ref="dataSource" />

</bean>

-----------------------------------------------------

 

SimpleJdbcDaoSupport 부터 jdbcMemberDAO 상속받은 dataSource프로퍼티에 데이터소스를 직접 와이어링할  있다

jdbcMemberDAO  자신의 dataSource프로퍼티가 설정되면 jdbcMemberDAO 자신이 사용할 SimpleJdbcTemplate 인스턴스를 내부적으로 생성해 둔다.

따라서 JdbcTemplate빈을 스프링에 명시적으로 선언할 필요가 사라진다

 

<bean id="memberDao" class="com.dao.jdbcMemberDAO">

     <property name="dataSource" ref="dataSource" />

</bean>

'Spring' 카테고리의 다른 글

[Spring] Aspect Oriented Programming(AOP)  (0) 2018.11.27
[Spring] Dependency Injection(DI)  (0) 2018.11.27
[Spring] 기본2  (0) 2018.11.27
[Spring] 요청 URI 매칭  (0) 2018.11.27
[Spring] @RequestBody / @ResponseBody  (0) 2018.11.27