1 분 소요

상속관계 매핑

스크린샷 2022-08-04 오전 9 47 55

  • 관계형 데이터베이스는 상속 관계 X
  • 슈퍼타입 서브타입 관계라는 모델링 기법이 객체 상속과 유사
  • 상속관계 매핑: 객체의 상속 구조와 DB의 슈퍼타입 서브타입 관계를 매핑

조인 전략

스크린샷 2022-08-04 오전 10 12 20

  • 각각 테이블로 변환
  • @Inheritance(strategy=InheritanceType.JOINED)
  • 장점
    - 테이블 정규화
    - 외래 키 참조 무결성 제약조건 활용가능
    - 저장공간 효율화
  • 단점
    - 조회시 조인을 많이 사용, 성능 저하
    - 조회 쿼리가 복잡함
    - 데이터 저장시 INSERT SQL 2번 호출
@Entity
@Inheritance(strategy=InheritanceType.JOINED) // 🌟
@DiscriminatorColumn
public class Item() {

  @Id @GeneratedValue
  private Long id;

  private String name;
  private int price;
}
@Entity
// @DiscriminatorValue("M") // default는 entity 이름
public class Movie() extends Item { // 🌟
  
  @Id @GeneratedValue
  private Long id;

  private String director;
  private String actor;
}

단일 테이블 전략

스크린샷 2022-08-04 오전 10 11 27

  • 통합 테이블로 변환
  • @Inheritance(strategy=InheritanceType.SINGLE_TABLE)
  • @Inheritance만 사용했을 때 default
  • 장점
    - 조인이 필요 없으므로 일반적으로 조회 성능이 빠름
    - 조회 쿼리가 단순함
  • 단점
    - 자식 엔티티가 매핑한 컬럼은 모두 null 허용
    - 단일 테이블에 모든 것을 저장하므로 테이블이 커질 수 있다. 상황에 따라서 조회 성능이 오히려 느려질 수 있다.
@Entity
@Inheritance(strategy=InheritanceType.SINGLE_TABLE) // 🌟
@DiscriminatorColumn
public class Item() {

  @Id @GeneratedValue
  private Long id;

  private String name;
  private int price;
}

@Inheritance의 전략만 SINGLE_TABLE으로 바꾸면 ITEM 테이블에 자식들의 속성이 모두 들어간다.

스크린샷 2022-08-04 오전 10 15 48

구현 클래스마다 테이블 전략

스크린샷 2022-08-04 오전 10 22 09

  • 서브타입 테이블로 변환
  • @Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
  • 이 전략은 DBA와 ORM 전문가 둘 다 추천하지 않는다.
  • 장점
    - 서브타입을 명확하게 구분해서 처리할 때 효과적
    - not null 제약조건 사용 가능
  • 단점
    - 여러 자식 테이블을 함께 조회할 때 성능이 느림 (UNION SQL 필요)
    - 자식 테이블을 통합해서 쿼리하기 어려움
@Entity
@Inheritance(strategy=InheritanceType.TABLE_PER_CLASS) // 🌟
@DiscriminatorColumn
public abstract class Item() { // 🌟 abstract

  @Id @GeneratedValue
  private Long id;

  private String name;
  private int price;
}

이 경우에는 ITEM 테이블이 만들어지지 않고, 그 자식(MOVIE) 테이블에 부모의 속성이 추가되어 만들어진다.

스크린샷 2022-08-04 오전 10 27 58



💛 개인 공부 기록용 블로그입니다. 👻

맨 위로 이동하기