본문 바로가기

mapping3

[JPA] 고급 매핑 상속관계 매핑 · 관계형 데이터베이스는 상속 관계 X · 슈퍼타입, 서브타입 관계라는 모델링 기법이 객체 상속과 유사 · 상속관계 매핑: 객체의 상속과 구조와 DB의 슈퍼타입, 서브타입 관계를 매핑 · 슈퍼타입, 서브타입 논리 모델을 실제 물리 모델로 구현하는 방법 - 각각 테이블로 변환 → 조인 전략 - 통합 테이블로 변환 → 단일 테이블 전략 - 서브타입 테이블로 변환 → 구현 클래스마다 테이블 전략 주요 어노테이션 · @Inheritance(strategy = InheritanceType.XXX) - JOINED: 조인전략 - SINGLE_TABLE: 단일 테이블 전략 - TABLE_PER_CLASS: 구현 클래스마다 테이블 전략 · @DiscriminatorColumn(name = "DTYPE").. 2023. 10. 31.
[JPA] 다양한 연관관계 매핑 연관관계 매핑시 고려사항 1. 다중성 · 다대일: @ManyToOne · 일대다: @OneToMany · 일대일: @OneToOne · 다대다: @ManyToMany 2. 단방향, 양방향 테이블 · 외래 키 하나로 양쪽 조인 가능 · 방향이라는 개념 X 객체 · 참조용 필드가 있는 쪽으로만 참조 가능 · 한쪽만 참조하면 단방향 · 양쪽이 서로 참조하면 양방향 3. 연관관계의 주인 · 테이블은 외래 키 하나로 두 테이블이 연관관계를 맺음 · 객체 양방햔 관계는 A→B, B→A 처럼 참조가 2개 · 연관관계의 주인: 외래 키를 관리하는 참조 · 주인의 반대편: 외래 키에 영향을 주지 않고 단순 조회만 가능 다대일 단방향 · 가장 많이 사용하는 연관관계 · 다대일의 반대는 일대다 다대일 양방향 · 외래 키가 .. 2023. 10. 30.
[JPA] 연관관계 매핑 연관관계 용어 · 방향(Direction): 단방향, 양방향 · 다중성(Multiplicity): 다대일(N:1), 일대다(1:N), 일대일(1:1), 다대다(N:M) · 연관관계의 주인(Owner): 객체 양방향 연관관계는 관리 주인 필요 연관관계가 필요한 이유 · 객체를 테이블에 맞추어 데이터 중심 모델링을 하면, 협력 관계를 만들 수 없다. · 테이블은 외래 키로 조인을 사용해 연관된 테이블을 찾는다. · 객체는 참조를 사용해 연관된 객체를 찾는다. · 테이블과 객체 사이에는 큰 간격이 있다. 단방향 연관관계 · 객체 지향 모델링 (객체의 참조와 테이블의 외래 키를 매핑) @Entity public class Member{ @Id @GeneratedValue private Long id; @Colu.. 2023. 10. 18.