다양한 연관관계 매핑(2) (일대일, 다대다)
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 프로그래밍