Post

(JPA)임베디드 타입

임베디드 타입

임베디드 타입?

  • 새로운 값 타입을 직접 정의 할 수 있다.
  • JPA는 임베디드 타입이라 한다.
  • 주로 기본 값 타입을 모아서 만들어서 복합 값 타입 이라고도 한다.
  • int, String과 같은 값 타입

임베디드 타입 사용법

  • @Embeddable: 값 타입을 정의하는 곳에 표시
  • @Embedded: 값 타입을 사용하는 곳에 표시
  • 기본 생성자는 필수로 있어야 한다.

임베디드 타입의 장점

  • 재사용이 가능하다.
  • 응집도가 높다.
  • 해당 값 타입만 사용하는 의미 있는 메서드를 만들 수 있다.
  • 임베디드 타입을 포함한 보든 값 타입은, 값 타입을 소유한 Entity의 생명주기에 의존한다.

임베디드 타입과 테이블 매핑

  • 임베디드 타입을 사용하던 안하던 DB 테이블과의 매핑은 달라지는게 없다.
  • 객체와 테이블을 아주 세밀하게 매핑하는 것이 가능하다.
  • 잘 설계한 ORM 애플리케이션은 테이블의 수보다 클래스의 수가 더 많다.

임베디드 타입 예제

  • 회원 엔티티는 이름, 근무 시작일, 근무 종료일, 주소 도시, 주소 번지, 주소 우편번호를 가진다.
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    
    @Entity
    public class Member {
      @Id
      @GeneratedValue
      private Long id;
        
      @Column(name = "username")
      private String username;
        
      //기간
      private LocalDateTime = startDate;
      private LocalDateTime = endDate;
        
      //주소
      private String city;
      private String street;
      private String zipcode;
    }
    
  • 위에 엔티티에서 묶을 수 있는 값 타입을 임베디드 타입으로 변경 할 수 있다.
1
2
3
4
5
@Embeddable
public class Period {
    private LocalDateTime = startDate;
    private LocalDateTime = endDate;
}
  • 기간에 대한 필드 값을 가지고 있는 객체
1
2
3
4
5
6
@Embeddable
public class Address {
    private String city;
    private String street;
    private String zipcode;
}
  • 주소에 대한 필드 값을 가지고 있는 객체
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@Entity
public class Member {
    @Id
    @GeneratedValue
    private Long id;
    
    @Column(name = "username")
    private String username;
    
    //기간
    @Embedded
    private Preiod preiod;
    
    //주소
    @Embedded
    private Address address;
}
  • 임베디드 타입으로 변경 한 후의 멤버 엔티티

임베디드 타입과 연관관계

  • 임베디드 타입 안에는 또 다른 임베디드 타입이 있을 수 있고, 엔티티 또한 있을 수 있다.

속성의 재정의

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
@Entity
public class Member {
    @Id
    @GeneratedValue
    private Long id;
    
    @Column(name = "username")
    private String username;
    
    //기간
    @Embedded
    private Period period;
    
    //집주소
    @Embedded
    @AttributeOverrides({
        @AttributeOverride(name = "city",
            column = @Column(name = "home_city")),
        @AttributeOverride(name = "street",
            column = @Column(name = "home_street")),
        @AttributeOverride(name = "zipcode",
            column = @Column(name = "home_zipcode"))
     })
    private Address homeAddress;
    
    //회사주소
    @Embedded
    @AttributeOverrides({
        @AttributeOverride(name = "city",
            column = @Column(name = "work_city")),
        @AttributeOverride(name = "street",
            column = @Column(name = "work_street")),
        @AttributeOverride(name = "zipcode",
            column = @Column(name = "work_zipcode"))
     })
    private Address workAddress;
}
  • 한 엔티티에서 같은 값 타입을 사용하면 에러가 발생한다.
    • 컬럼명이 중복 되기 때문
  • @AttributeOverrides, @AttributeOverride를 사용해서 컬럼명 속성을 재정의 하여 해결이 가능하다.
  • 자주 사용하지는 않는다.

임베디드 타입과 null

1
2
@Embedded
private Period period = null;
  • 임베디드 타입이 null이면 매핑한 컬럼값은 모두 null이다.

REFERENCE


#JPA_임베디드_타입

This post is licensed under CC BY 4.0 by the author.