JPA - 엔티티 매핑

bp.chys·2020년 5월 7일
0

JPA

목록 보기
2/15

객체와 테이블 매핑

@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)
validateDDL생성 시에 유니크 제약 조건 생성
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 프로그래밍, 김영한 저
profile
하루에 한걸음씩, 꾸준히

0개의 댓글