(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.