자바 ORM 표준 JPA 프로그래밍

다양한 연관관계 매핑(2) (일대일, 다대다)

깊게 생각하고 최선을 다하자 2022. 9. 11. 19:59

1) 일대일(1:1)

- 일대일 관계는 그 반대도 일대일

  주 테이블이나 대상 테이블 중 외래 키 선택 가능

  외래 키에 데이터베이스 유니크(UNI) 제약 조건 추가

 

(1-1) 일대일: 주 테이블에 외래 키 단방향

- 다대일 단방향 매핑과 유사

(1-2) 일대일: 주 테이블에 외래 키 양방향 

- 다대일 양방향 매핑처럼 외래 키가 있는 곳이 연관 관계의 주인입니다.

  반대편은 mappedBy를 적용합니다. 

 

(1-3) 일대일 정리

(1) 주 테이블에 외래 키

- 주 객체가 대상 객체의 참조를 가지는 것처럼 

  주 테이블에 외래 키를 두고 대상 테이블을 찾음

- 객체지향 개발자 선호

- JPA 매핑 편리

- 장점: 주 테이블만 조회해도 대상 테이블에 데이터가 있는지 확인 가능

- 단점: 값이 없으면 외래 키에 null 허용

 

(2) 대상 테이블에 외래 키

- 대상 테이블에 외래 키가 존재

- 전통적인 데이터베이스 개발자 선호

- 장점: 주 테이블과 대상 테이블을 일대일에서 일대다 관계로 변경할 때 테이블 구조 유지

- 단점: 프록시 기능의 한계로 지연 로딩으로 설정해도 항상 즉시 로딩됨 

 

 

2) 다대다(N:M)

- 관계형 데이터베이스는 정규화된 테이블 2개로 다대다 관계를 표현할 수 없음

-> 연결 테이블을 추가해서 일대다, 다대일 관계로 풀어내야 함

-> 단, 객체는 컬렉션 2개를 사용해서 객체 2개로 다대다 관계가 가능합니다.

 

- @ManyToMany를 사용하고, @JoinTable로 연결 테이블을 지정할 수 있습니다. 

  다대다 매핑도 양방향, 단방향이 가능합니다. 

 

 

2-1) 다대다 매핑의 한계

- 편리해 보이지만 실무에서 사용할 수 없음

- 연결 테이블이 단순히 연결만 하고 끝나지 않음

- 주문 시간, 수량 같은 데이터가 들어올 수 있음 

 

2-2) 다대다 한계 극복

- 연결 테이블용 엔티티 추가(연결 테이블을 엔티티로 승격)

- @ManyToMany -> @OneToMany, @ManyToOne

 

참고

김영한 자바 ORM 표준 JPA 프로그래밍