- 일대일 관계는 그 반대도 일대일
- 주 테이블이나 대상 테이블 중에 외래 키를 선택 가능
- 주 테이블에 외래 키 넣기
- 대상 테이블에 외래 키 넣기
- 외래 키에 데이터베이스 유니크 제약조건을 추가해야 한다.
일대일 : 주 테이블에 외래 키 단방향
- 회원과 사물함의 관계
- 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가 제공하는 기본 프록시 기능에 한계가 생기 게 되는데, 지연 로딩으로 설정해도 항상 즉시 로딩된다.