• @Entity로 정의하는 객체
• 데이터가 변해도 식별자로 지속해서 추적 가능
• 예)회원엔티티의 키나 나이 값 을변경해도 식별자로 인식가능
• int, Integer, String처럼 단순히 값으로 사용하는 자바 기본 타입이나 객체
• 식별자가 없고 값만 있으므로 변경시 추적 불가
• 예) 숫자 100을 200으로 변경하면 완전히 다른 값으로 대체
예) String name, int age
예) 회원을 삭제하면 이름, 나이 필드도 함께 삭제
-> 생명주기를 엔티티의 의존
예) 회원 이름 변경시 다른 회원의 이름도 함께 변경되면 안됨
-> 값 타입은 공유하면X
참고: 자바의 기본 타입은 절대 공유X
- int, double 같은 기본 타입(primitive type)은 절대 공유X
- 기본 타입은 항상 값을 복사함 (자바는 call by referece가 없다.)
- Integer같은 래퍼 클래스나 String 같은 특수한 클래스는 공유 가능한 객체이지만 변경X
@Embeddable: 값 타입을 정의하는 곳에 표시 기본 생성자 필수
@Embedded: 값 타입을 사용한는 곳에 표시(기본 생성자 필수)
멤버 엔티티
@Embedded private Address homeAddress;
Adderess 엔티티
@Embeddable public class Address { private String city; private String street; private String zipcode; public Address() { } public Address(String city, String street, String zipcode) { this.city = city; this.street = street; this.zipcode = zipcode; }
임베디드 타입과 테이블 매핑
- 임베디드 타입은 엔티티의 값일 뿐이다.
- 임베디드 타입을 사용하기 전과 후의 매핑하는 테이블은 같다.
- 객체와 테이블을 아주 세밀하게(find-grained) 매핑하는 것이 가능
- 잘 설계한 ORM 애플리케이션은 매핑한 테이블의 수보다 클래스의 수가 더 많음
만약 한 엔티티에서 같은 값 타입을 사용하면?? --> 컬럼 명이 중복됨
임베디드 타입의 값이 null이면 매핑한 컬럼 값은 모두 null
임베디드 타입의 장점
- 재사용
- 높은 응집도
- 해당 값 타입만 사용하는 의미 있는 메소드를 만들 수 있음
- 임베디드 타입을 포함한 모든 값 타입은, 값 타입을 소유한 엔티티에 생명주기를 의존함