[자바 ORM 표준 JPA 프로그래밍] 6.3 일대일
개발서적/자바 ORM 표준 JPA

[자바 ORM 표준 JPA 프로그래밍] 6.3 일대일

Reference. 자바 ORM 표준 JPA 프로그래밍

책 목차 및 이전 글

더보기

일대일 관계의 특징

  • 일대일 관계는 그 반대도 일대일 관계
  • 테이블 관계에선 일대다, 다대일은 항상 다(N)쪽이 외래키를 가짐 일대일은 주테이블, 대상테이블 어느 곳이나 외래키를 가질 수 있음 ( 외래키 선택 필요 )
    • 주 테이블에 외래키
      • 주 테이블에 외래 키를 두고 대상 테이블을 참조
      • 외래 키를 개체 참조와 비슷하게 사용함으로 객체지향 개발자들이 선호
      • 장점: 주 테이블이 외래 키를 가지므로 주테이블을 통해 대상 테이블 관계 확인 가능
    • 대상 테이블에 외래키
      • 전통적인 DB 개발자들은 대상 테이블에 외래 키를 두는 것을 선호
      • 장점: 테이블 관계를 일대일 → 일대다로 변경할 때 테이블 구조를 그대로 유지

6.3.1 주 테이블에 외래 키

  • 객체지향 개발자들은 주 테이블에 외래키가 있는 것을 선호
  • JPA도 주 테이블에 외래 키가 있으면 편리하게 매핑 가능

단방향

  • 회원과 사물함은 일대일 단방향 관계, MEMBER가 주테이블이고 LOCKER는 대상테이블

    코드를 통한 단방향 예제 코드
    • 다대일 단방향(@ManyToOne)과 유사
    @Entity
    public class Member {
    		...
    		@OneToOne
    		@JoinColumn(name = "LOCKER_ID")
    		private Locker locker
    }
    
    @Entity
    public class Locker {
    		@Id @GeneratedValue
    		@Column(name = "LOCKER_ID")
    		private Long id;
    		
    		private String name;
    		...
    }

양방향

  • 양방향이므로 연관관계 주인을 지정
  • MEMBER 테이블이 외래 키를 가지므로 Member.locker가 연관관계의 주인
  • 반대 매핑인 사물함의 Locker.membermappedBy를 선언하여 주인이 아님을 설정

    코드를 통한 양방향 예제 코드
    @Entity
    public class Member {
    		...
    		@OneToOne
    		@JoinColumn(name = "LOCKER_ID")
    		private Locker locker
    }
    
    @Entity
    public class Locker {
    		@Id @GeneratedValue
    		@Column(name = "LOCKER_ID")
    		private Long id;
    		
    		private String name;
    
    		@OneToOne(mappedBy = "locker")
    		private Member member;
    		...
    }

6.3.2 대상 테이블에 외래키

단방향

  • 일대일 관계에선 대상 테이블에 외래 키가 있는 단방향 관계는 JPA 지원하지 않음
  • 아래의 그림처럼 매핑할 방법이 없고, 양방향 관계를 설정해야 가능

양방향

코드를 통한 양방향 예제 코드
@Entity
public class Member {
		@Id @GeneratedValue
		@Column(name = "MEMBER_ID")
		private Long id;

		private String username;

		@OneToOne(mappedBy = "member")
		private Locker locker
}

@Entity
public class Locker {
		@Id @GeneratedValue
		@Column(name = "LOCKER_ID")
		private Long id;
		
		private String name;

		@OneToOne
		@JoinColumn(name = "MEMBER_ID")
		private Member member;
		...
}