(JPA) 일대일 (1 : 1)

  • by

일대일 관계

  • 일대일 관계는 그 반대도 일대일
  • 메인 테이블 또는 타겟 테이블 사이에서 외래 키를 선택할 수 있습니다.

    • 메인 테이블의 외래 키
    • 목표 테이블의 외래 키

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

일대일 : 메인 테이블에 대한 외래 키의 한 방향


  • 다대일(@ManyToOne) 단방향 매핑과 유사

1대 1: 메인 테이블에 대한 외래 키 양방향


  • 다대일 양방향 매핑처럼 외래 키가 있는 위치가 관련 관계의 소유자
  • 다른 쪽은 mappedBy 적용

일대일: 목표 테이블에 대한 외래 키의 한 방향


  • 단방향 관계는 JPA 지원 X
  • 양방향 관계는 지원

일대일: 목표 테이블에 대한 외래 키 양방향


  • 일대일 메인 테이블에 대한 외래 키의 양방향 및 매핑 방법은 동일

일대일 정리

  • 메인 테이블의 외래 키
    • 메인 오브젝트가 타겟 오브젝트의 참조를 가지도록(듯이)
      메인 테이블에 외래 키를 놓고 대상 테이블을 찾습니다.

    • 객체 지향 개발자가 선호
    • JPA 매핑의 편리함
    • 장점: 메인 테이블만 쿼리해도 대상 테이블에 데이터가 있는지 확인할 수 있습니다.

    • 단점: 값이 없는 경우 외래 키에 NULL 허용
  • 목표 테이블의 외래 키
    • 대상 테이블에 외래 키가 있음
    • 전통적인 데이터베이스 개발자가 선호
    • 장점 : 기본 테이블과 대상 테이블을 일대일에서 일대 다 관계로 변경할 때 테이블 구조 유지
    • 단점: 프록시 기능의 한계로 지연로드로 설정해도 항상 즉시로드됩니다.


출처: https://www.inflearn.com/course/ORM-JPA-Basic