일대일 관계
- 일대일 관계는 그 반대도 일대일
- 메인 테이블 또는 타겟 테이블 사이에서 외래 키를 선택할 수 있습니다.
- 메인 테이블의 외래 키
- 목표 테이블의 외래 키
- 외래 키에 데이터베이스 고유(UNI) 제약 조건 추가
일대일 : 메인 테이블에 대한 외래 키의 한 방향
- 다대일(@ManyToOne) 단방향 매핑과 유사
1대 1: 메인 테이블에 대한 외래 키 양방향
- 다대일 양방향 매핑처럼 외래 키가 있는 위치가 관련 관계의 소유자
- 다른 쪽은 mappedBy 적용
일대일: 목표 테이블에 대한 외래 키의 한 방향
- 단방향 관계는 JPA 지원 X
- 양방향 관계는 지원
일대일: 목표 테이블에 대한 외래 키 양방향
- 일대일 메인 테이블에 대한 외래 키의 양방향 및 매핑 방법은 동일
일대일 정리
- 메인 테이블의 외래 키
- 메인 오브젝트가 타겟 오브젝트의 참조를 가지도록(듯이)
메인 테이블에 외래 키를 놓고 대상 테이블을 찾습니다. - 객체 지향 개발자가 선호
- JPA 매핑의 편리함
- 장점: 메인 테이블만 쿼리해도 대상 테이블에 데이터가 있는지 확인할 수 있습니다.
- 단점: 값이 없는 경우 외래 키에 NULL 허용
- 메인 오브젝트가 타겟 오브젝트의 참조를 가지도록(듯이)
- 목표 테이블의 외래 키
- 대상 테이블에 외래 키가 있음
- 전통적인 데이터베이스 개발자가 선호
- 장점 : 기본 테이블과 대상 테이블을 일대일에서 일대 다 관계로 변경할 때 테이블 구조 유지
- 단점: 프록시 기능의 한계로 지연로드로 설정해도 항상 즉시로드됩니다.