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 사용됨
- RoleDaoSql
- NamedParameterJdbcTemplate, SimpleJdbcInsert
- SQL 실행 편리하게 하도록 Spring JDBC에서 제공하는 객체
- DB연결을 위해 내부적으로 DataSource 사용
'Spring > Spring JDBC' 카테고리의 다른 글
[Spring] [Spring JDBC] RowMapper와 @NoArgsConstructor, @Setter (0) | 2022.10.06 |
---|---|
[Spring] [Spring JDBC] 5. Spring JDBC 실습 진행 3 - insert(), update() (2) | 2022.09.20 |
[Spring] [Spring JDBC] 4. Spring JDBC 실습 진행 2 - selectAll() (1) | 2022.09.20 |
[Spring] [Spring JDBC] 3. Spring JDBC 실습 진행 (0) | 2022.09.19 |
[Spring] [Spring JDBC] 1. Spring JDBC 개요 (0) | 2022.09.19 |