두두의 IT/Spring

DAO, DTO, VO 차이

두두연 2023. 4. 17. 15:38
728x90

DAO (Data Access Object)

  • DataBase의 data에 접근하기 위한 객체로, 데이터 삽입, 삭제, 조회 등 조작할 수 있는 기능을 수행함
  • DataBase 접근 로직과 비지니스 로직을 분리하기 위해 사용함
  • DB와 연결할 Connection 까지 설정되어 있는 경우가 많음
  • 현재 많이 쓰이는 Mybatis 등을 사용할 경우 커넥션풀까지 제공되고 있기 때문에 DAO를 별도로 만드는 경우는 드뭄

 

DTO (Data Transfer Object)

  • 계층 간(Controller, View, Business, Persistent Layer, DataBase) 데이터 교환을 하기 위해 사용하는 객체(Java Beans)
  • 로직을 가지지 않는 순수한 데이터 객체 (getter & setter 메소드만 가진 클래스)
  • 유저가 자신의 브라우저에서 데이터를 입력하여 form에 있는 데이터를 DTO에 넣어서 전송할 때 사용
  • 주로 비동기 처리를 할 때 사용

 

VO (Value Object)

  • 단순히 값을 표현하기 위해 쓰임
  • 사용하는 도중에 변경 불가능한 Read-Only 클래스
  • equals()와 hashcode() 를 오버라이딩 하는 것이 핵심 역할
  • VO 내부에 선언된 속성(필드)의 모든 값들이 VO 객체마다 값이 같아야, 똑같은 객체라고 판별함
  • 테이블 내에 있는 속성 외에 추가적인 속성을 가질 수 있으며, 여러 테이블(A, B, C)에 대한 공통 속성을 모아서 만든 BaseVO 클래스를 상속받아서 사용할 수도 있음

 

DTO와 VO의 차이점

DTO VO
setter를 통한 가변 불변

 

Java Beans

  • Java로 작성된 소프트웨어 컴포넌트를 지칭하는 단어
  • 비즈니스 로직 부분을 담당하는 Java 프로그램 단위
  • JSP페이지가 복잡한 자바 코드로 구성되는 것을 피할 수 있음
  • 재사용 가능한 컴포넌트를 만들 수 있음