김영한님의 자바 ORM 표준 JPA 프로그래밍 - 기본편 정리
1. 연관관계 매핑시 고려사항 3가지
- 다중성
- 단방향, 양방향
- 연관관계의 주인
2. 다중성
- 다대일: @ManyToOne
- 일대다: @OneToMany
- 일대일: @OneToOne
- 다대다: @ManyToMany -> 실무에서 사용 X
3. 단방향, 양방향
- 테이블
(1) 외래키 하나로 양쪽 조인 가능
(2) 사실 방향이라는 개념이 없음
- 객체
(1) 참조용 필드가 있는 쪽으로만 참조 가능
(2) 한쪽만 참조하면 단방향
(3) 양쪽이 서로 참조하면 양방향
- 연관관계의 주인
(1) 테이블은 외래키 하나로 두 테이블이 연관관계를 맺음
(2) 객체 양방향 관계는 A->B, B->A 처럼 참조가 2군데
(3) 객체 양방향 관계는 참조가 2군데 있음. 둘중 테이블의 외래키를 관리할 곳을 지정해야함
(4) 연관관계의 주인: 외래키를 관리하는 참조
(5) 주인의 반대편: 외래키에 영향을 주지 않음. 단순 조회만 가능
4. 다대일: @ManyToOne
- 단방향
(1) 가장 많이 사용하는 연관관계
(2) 다대일 중 다(N)에 @ManyToOne 붙여서 다대일을 명시
(3) 다대일 중 다(N)에 @JoinColumn 으로 FK 명시
- 양방향
(1) 다대일 단방향에서 테이블은 변화없이 일에서 다(N)쪽으로 단방향 추가한 상태 -> 양쪽을 서로 참조하도록 개발
(2) 다대일 중 다(N)에는 단방향과 마찬가지로 @ManyToOne, @JoinColumn
(3) 다대일 중 일(1)에는 @OneToMany(mappedBy=”“)를 붙여줌으로써 양방향임을 명시해주고 mappedBy로 연관관계 주인 명시
> 다대일 중 일에 mappedBy를 명시해주면서 다(N)를 연관관계 주인으로 지정
5. 일대다: @OneToMany
- 단방향
(1) 일대다 단방향은 일대다(1:N)에서 일(1)이 연관관계의 주인
(2) 테이블 일대다 관계는 항상 다(N) 쪽에 외래키가 있음
(3) 객체와 테이블의 차이 때문에 반대편 테이블의 외래키를 관리하는 특이한 구조
(4) @JoinColumn을 꼭 사용해야 함. 그렇지 않으면 조인 테이블 방식을 사용함(중간에 테이블을 하나 추가함)
(5) 일대다 단방향 매핑의 단점
> 엔티티가 관리하는 외래키가 다른 테이블에 있음
> 연관관계 관리를 위해 추가로 UPDATE SQL 실행
(6) 일대다 단방향 매핑보다는 다대일 양방향 매핑을 사용하자
- 양방향
- 이런 매핑은 공식적으로 존재 X
- @JoinColumn(insertable=false, updatable=false)
- 읽기 전용 필드를 사용해서 양방향 처럼 사용하는 방법
- 다대일 양방향을 사용하자
6. 일대일: @OneToOne
- 일대일 관계는 그 반대도 일대일
- 주 테이블이나 대상 테이블 중에 외래 키 선택 가능
> 주 테이블에 외래 키
> 대상 테이블에 외래 키
- 외래 키에 데이터베이스 유니크(UNI) 제약조건 추가
- 일대일: 주 테이블에 외래 키 단방향
- 다대일(@ManyToOne) 단방향 매핑과 유사
- 주 테이블에 외래 키를 설정한 단방향 모델
> 주 테이블이란 주로 사용하는 테이블
- 외래 키를 설정한 주 테이블의 객체에 @OneToOne, @JoinColumn
- 주 테이블 외래 키 양방향
- 다대일 양방향 매핑 처럼 외래 키가 있는 곳이 연관관계의 주인
> 외래 키를 설정한 주 테이블의 객체에는 @OneToOne, @JoinColumn
- 반대편은 mappedBy 적용
> 반대편 객체에는 @OneToOne(mappedby="")
- 대상 테이블 외래 키 단방향
- 단방향 관계는 JPA 지원 X
- 양방향 관계는 지원
- 대상 테이블 외래 키 양방향
- 일대일 주 테이블에 외래 키 양방향과 매핑 방법은 같음
'개발 > Java & Kotlin' 카테고리의 다른 글
[JPA] 고급 매핑 (0) | 2022.07.18 |
---|---|
[Java] 트리 (0) | 2022.07.14 |
[Java] 정렬 (2) (0) | 2022.07.13 |
[JPA] 연관관계 매핑 기초 (0) | 2022.07.13 |
[Java] 정렬 (1) (0) | 2022.07.12 |