객체와 테이블 매핑
@Entity
- @Entity 어노테이션이 붙은 클래스는 JPA가 관리한다.
- 엔티티 클래스는 JPA 스펙상
public 기본 생성자
를 필수로 가지고 있어야 한다.
- final 클래스, enum, interface, inner클래스는 엔티티가 될 수 없다.
- 저장할 필드에 final을 사용하지 않는다.
@Table
- @Table 어노테이션은 엔티티와 매핑할 테이블을 지정한다.
속성 | 기능 | 기본값 |
---|
name | 매핑할 테이블 이름 | 엔티티 이름을 사용 |
catalog | 데이터베이스 catalog 매핑 | |
schema | 데이터베이스 schema매핑 | |
uniqueConstraints(DDL) | DDL생성 시에 유니크 제약 조건 생성 | |
데이터베이스 스키마 자동 생성
- 애플리케이션 실행 시점에 DDL을 자동으로 생성
- 테이블 중심 → 객체 중심
- 데이터베이스 방언을 활용해서 데이터베이스에 맞는 적절한 DDL 생성
create
, create-drop
으로 생성된 DDL은 개발 장비에서만 사용하자. 실제 운영서버에서 사용하다가 큰 일이 벌어질지도 모른다.
update
, validate
정도 활용하는 것은 다른 데이터들을 건드리지 않으면서 디버깅과 업데이트를 동시에 진행하는 효과가 있다.
옵션 | 설명 |
---|
create | 매핑할 테이블 이름 |
create-drop | 데이터베이스 catalog 매핑 |
update | 변경분만 반영(운영 DB에는 사용 x) |
validate | DDL생성 시에 유니크 제약 조건 생성 |
none | 사용하지 않음 |
필드와 컬럼 매핑
@Column
- DDL 생성기능
- 제약조건 추가
@Column(nullable = false, length = 10)
- Unique 제약 조건은 컬럼에 할 경우, 제약 조건 이름이 랜덤으로 결정된다 따라서 아래 처럼 테이블에 거는 것이 좋다.
- 유니크 제약조건 추가가 필요한 경우 :
@Table(uniqueConstraints = {@UniqueConstraint(name="NAME_AGE_UNIQUE", columneNames = {"NAME", "AGE"})})
- DDL 생성 기능은 DDL을 자동 생성할 때만 사용되고 JPA의 실행 로직에는 영향을 주지 않는다.
@Enumerated
- 자바 enum을 매핑할 때 사용
EnumType.ORDINAL
: enum의 순서대로 데이터베이스를 저장
EnumType.STRING
: enum의 이름을 데이터베이스에 저장
@Lob
- @Lob에는 지정할 수 있는 속성이 없다.
- 매핑하는 필드 타입이 문자면 CLOB 매핑. 나머지는 BLOCK 매핑
@Transient
- 필드 매핑을 지원하지 않는다.
- 데이터베이스에 저장도 하지 않고 조회도 하지 않는다.
- 주로 메모리상에서만 임시로 어떤 값을 보관하고 싶을 때 사용
기본키 매핑
@Id
- @Id만 사용해서 기본키를 직접 할당 시켜도 된다.
@GeneratedValue
IDENTITY: 데이터베이스에 위임
- pk 생성을 데이터베이스에 위임한다는 말은 객체의 id값이 테이블에 삽입이 되어야 비로소 id값이 생긴다는 것이다.
- 하지만 보통 JPA는 트랜잭션 커밋 시점에 INSERT SQL을 실행한다.
- IDENTITY 전략은 commit 시점이 아닌, em.persist() 시점에 즉시 INSERT SQL을 실행하고 DB에서 식별자를 조회한다는 특징이 있다.
SQUENCE: 데이터베이스 시퀀스 오브젝트 사용
- @SequenceGenerator 필요
- 데이터베이스 시퀀스는 유일한 값을 순서대로 생성하는 특별한 데이터베이스 오브젝트이다.
- 객체를 생성할 때, Sequence를 조회하는 쿼리를 날려서 id값을 얻어낸 뒤 매핑시켜준다.
@Entity
@SequenceGenerator(name = "MEMBER_SEQ_GENERATOR", sequenceName = "MEMBER_SEQ", initialValue = 1, allocationSize = 1)
public class Member {
@Id @GeneraedValue(strategy = Generation.SEQUENCE, generator = "MEMBER_SEQ_GENERATOR")
private Long id;
}
TABLE: 키 생성용 테이블 사용
- @TableGenerate 필요
- 키 생성 전용 테이블을 하나 만들어서 데이터베이스 시퀀스를 흉내내는 전략
- 장점 : 모든 데이터베이스에 적용 가능
- 단점 : 별도의 테이블을 만들어야 하므로 성능이슈가 존재
AUTO: 방언에 따라 자동 지정한다.
권장하는 식별자 전략?
- 기본키 제약 조건 : not null, unique, 불변!!
- 비즈니스 밸류와 관련이 적은 GeneratedValue로 pk를 사용하자.
- 권장 : Long형 + 대체키 + 키 생성전략 사용
참고자료
- 자바 ORM 표준 JPA 프로그래밍, 김영한 저