• 일대일 관계는 그 반대도 일대일
  • 주 테이블이나 대상 테이블 중에 외래 키를 선택 가능
    • 주 테이블에 외래 키 넣기
    • 대상 테이블에 외래 키 넣기
  • 외래 키에 데이터베이스 유니크 제약조건을 추가해야 한다.

일대일 : 주 테이블에 외래 키 단방향

주 테이블에 외래 키 단방향

  • 회원과 사물함의 관계
  • Member를 주 테이블로 보고 Member에 외래 키 제약조건을 넣거나 반대로 Locker에 member_id를 넣고 외래 키 제약조건을 넣어도 된다.
  • 다대일(@ManyToOne) 단방향 매핑과 유사하다.

일대일 : 주 테이블에 외래 키 양방향

주 테이블에 외래 키 양방향

  • 다대일 양방향 매핑처럼 외래 키가 있는 곳이 연관관계의 주인으로 설정한다.
  • 반대편은 mappedBy 적용
//Member

@Id @GeneratedValue
@Column(name = "MEMBER_ID")
private Long id;

@Column(name = "USERNAME")
private String username;

@OneToOne
@JoinColumn(name = "LOCKER_ID")
private Locker locker;
//Locker

@Id @GeneratedValue
@Column(name = "LOCKER_ID")
private Long id;

private String name;

@OneToOne(mappedBy = "locker")
private Member member;

일대일: 대상 테이블에 외래 키 단방향

대상 테이블에 외래 키 단방향

  • 단방향 관계는 JPA에서 지원하지 않는다.
  • 대신 양방향 관계는 가능하다.

일대일: 대상 테이블에 외래 키 양방향

대상 테이블에 외래 키 양방향

  • 사실 일대일 주 테이블에 외래 키 양방향과 매핑 방법은 같다.

일대일에서 외래 키 설정 방법

  • 주 테이블에 외래 키 설정하기
    • 주 객체가 대상 객체의 참조를 가지는 것처럼 주 테이블에 외래 키를 두고 대상 테이블을 찾는다.
    • 객체지향 개발자가 선호
    • JPA 매핑 편리하다.
    • 장점: 주 테이블만 조회해도 대상 테이블에 데이터가 있는지 확인이 가능하다.
    • 단점: 값이 없으면 외래 키에 null 허용하도록 설정해야 한다.
  • 대상 테이블에 외래 키 설정하기
    • 대상 테이블에 외래 키가 존재한다.
    • 전통적인 데이터베이스 개발자가 선호
    • 장점: 주 테이블과 대상 테이블을 일대일에서 일대다 관계로 변경할 때 테이블 구조를 유지할 수 있다.
    • 단점: JPA가 제공하는 기본 프록시 기능에 한계가 생기 게 되는데, 지연 로딩으로 설정해도 항상 즉시 로딩된다.