사용되는 어노테이션
어노테이션 | 설명 |
@Inheritance | 상속 매핑은 부모 클래스에 @Inheritance를 사용해야 한다. |
@DiscriminatorColumn | 부모 클래스에 구분 컬럼을 지정한다. 이 컬럼으로 저장된 자식 테이블을 구분할 수 있다. 기본값은 DTYPE이다. |
@DiscriminatorValue | 엔티티를 저장할 때 구분 컬럼에 입력할 값을 지정한다. 만약 영화 엔티티를 저장하면 구분 컬럼인 DTYPE에 값 M이 저장된다. 지정하지 않으면 엔티티 이름을 사용한다. |
@PrimaryKeyJoinColumn | 기본값으로 자식 테이블은 부모의 PK 컬럼명을 사용한다. 자식 테이블의 PK 컬럼명을 변경하고 싶을때 사용한다. |
조인 전략
각각을 모두 테이블로 만들고 조회할 때 조인을 사용한다.
장점 | 단점 | 특징 |
테이블 정규화 | 조회시 조인으로 인한 성능 저하 우려 | JPA 표준 명세는 구분 컬럼을 사용하도록 하지만 하이버네이트를 포함한 몇 몇 구현체는 구분 컬럼 없이도 동작한다. |
외래 키 참조 무결서 제약조건 활용 | 조회 쿼리 복잡 | |
저장공간 효율성 | INSERT 쿼리 두번 실행 |
테이블
엔티티
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
@DiscriminatorColumn(name = "DTYPE")
public abstract class Item {
@Id
@GeneratedValue
@Column(name = "ITEM_ID")
private Long id;
private String name;
private int price;
}
@Entity
@DiscriminatorValue("A")
public class Album extends Item{
private String artist;
}
@Entity
@DiscriminatorValue("M")
public class Movie extends Item{
private String director;
private String actor;
}
@Entity
@DiscriminatorValue("B")
@PrimaryKeyJoinColumn(name = "BOOK_ID")
public class Book extends Item{
private String author;
private String isbn;
}
단일 테이블 전략
테이블을 하나만 사용해서 통합한다.
장점 | 단점 | 특징 |
조인이 필요 없으므로 조회 성능이 빠르다 | 자식 엔티티가 매핑한 컬럼은 모두 null을 허용해야 한다. | 구분 컬럼을 꼭 사용해야 한다. |
조회 쿼리가 단순한다 | 단일 테이블에 모든 것을 저장하므로 테이블이 커질 수 있다. 따라서 조회 성능이 오히려 느려지는 경우가 있다. |
테이블
엔티티
@Entity
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "DTYPE")
public abstract class Item {
@Id
@GeneratedValue
@Column(name = "ITEM_ID")
private Long id;
private String name;
private int price;
}
@Entity
@DiscriminatorValue("A")
public class Album extends Item{
private String artist;
}
@Entity
@DiscriminatorValue("M")
public class Movie extends Item{
private String director;
private String actor;
}
@Entity
@DiscriminatorValue("B")
@PrimaryKeyJoinColumn(name = "BOOK_ID")
public class Book extends Item{
private String author;
private String isbn;
}
구현 클래스마다 테이블 전략
서브 타입마다 하나의 테이블을 만든다. 일반적으로 추천하지 않는 전략이다.
장점 | 단점 | 특징 |
서브 타입을 구분해서 처리할 때 효과적 | 여러 테이블을 함께 조회할 때 성능이 느리다. | 구분 컬럼을 사용하지 않는다. |
not null 제약조건을 사용할 수 있다. | 자식 테이블을 통합해서 쿼리하기 어렵다. |
테이블
엔티티
@Entity
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public abstract class Item {
@Id
@GeneratedValue
@Column(name = "ITEM_ID")
private Long id;
private String name;
private int price;
}
@Entity
public class Album extends Item{
private String artist;
}
@Entity
public class Movie extends Item{
private String director;
private String actor;
}
@Entity
public class Book extends Item{
private String author;
private String isbn;
}
728x90
'JVM > JPA' 카테고리의 다른 글
@MapsId (0) | 2023.06.18 |
---|---|
@MappedSuperclass (0) | 2023.06.17 |
복합키 매핑 @IdClass, @EmbeddedId (0) | 2023.06.16 |
@ManyToMany (0) | 2023.06.16 |
@OneToOne (0) | 2023.06.16 |