본문 바로가기

Spring/Spring JDBC

[Spring] [Spring JDBC] 2. Spring JDBC 실습 개요

DTO란?

  • DTO란 Data Transfer Object의 약자입니다.
  • 계층간 데이터 교환을 위한 자바빈즈입니다.
  • 여기서의 계층이란 컨트롤러 뷰, 비지니스 계층, 퍼시스턴스 계층을 의미합니다.
  • 일반적으로 DTO는 로직을 가지고 있지 않고, 순수한 데이터 객체입니다.
  • 필드와 getter, setter를 가진다. 추가적으로 toString(), equals(), hashCode()등의 Object 메소드를 오버라이딩 할 수 있습니다.

 

DTO의 예

public class ActorDTO {
    private Long id;
    private String firstName;
    private String lastName;
    public String getFirstName() {
        return this.firstName;
    }
    public String getLastName() {
        return this.lastName;
    }
    public Long getId() {
        return this.id;
    }
    // ......
}

 

DAO란?

  • DAO란 Data Access Object의 약자로 데이터를 조회하거나 조작하는 기능을 전담하도록 만든 객체입니다.
  • 보통 데이터베이스를 조작하는 기능을 전담하는 목적으로 만들어집니다.

 

ConnectionPool 이란?

  • DB연결은 비용이 많이 듭니다.
  • 커넥션 풀은 미리 커넥션을 여러 개 맺어 둡니다.
  • 커넥션이 필요하면 커넥션 풀에게 빌려서 사용한 후 반납합니다.
  • 커넥션을 반납하지 않으면 어떻게 될까요?
 

DataSource란?

  • DataSource는 커넥션 풀을 관리하는 목적으로 사용되는 객체입니다.
  • DataSource를 이용해 커넥션을 얻어오고 반납하는 등의 작업을 수행합니다.

 

Spring JDBC를 이용한 DAO작성 실습

  • ApplicationContext
    • ApplicationConfig 설정 파일로 가짐
    • ApplicationConfig를 통해 스프링 컨테이너에 RoleDAO를 빈으로 등록하고 있다
    • DBConfig 클래스를 import

 

  • DBConfig
    • dataSource, transcationManager 객체 생성
 
  • RoleDao
    • NamedParameterJdbcTemplate, SimpleJdbcInsert 객체를 가짐(여기서 초기화)
    • 개발자는, 파라미터와 SQL을 가장 많이 신경써야 한다
      • RoleDaoSql
        • 나중에 SQL 변경 시, 편하게 수정할 수 있도록 따로 객체를 만듬
      • Role
        • 한 건의 Role 정보를 저장하고 전달하는 목적으로 RoleDto 사용됨

 

  • NamedParameterJdbcTemplate, SimpleJdbcInsert
    • SQL 실행 편리하게 하도록 Spring JDBC에서 제공하는 객체 
    • DB연결을 위해 내부적으로 DataSource 사용