본문 바로가기

Dev/JPA

RS) 객체 테이블 매핑

@Entity 어노테이션

  • @Entity가 붙은 클래스는 JPA가 관리를 하겠다라는 엔티티를 나타낸다.
  • JPA를 사용하여 테이블을 매핑하기 위해서는 @Entity를 필수로 가져야한다.

주의 점

  • 기본 생성자를 필수로 가져야한다 (파라미터가 없는 public 또는 protected 생성자)
  • final 클래스, enum, interface, inner클래스 사용 X
  • 저장할 필드에 final 사용 X

@Table 어노테이션

  • @Table은 엔티티와 매핑할 테이블 지정
    • name : 매핑할 테이블 이름 → 기본 값 : 엔티티 이름을 사용
    • catalog  : 데이터베이스 catalog 매핑
    • schema : 데이터베이스 schema 매핑
    • uniqueConstraints : DDL 생성 시에 유니크 제약 조건 생성

데이터베이스 스키마 자동 생성 (hibernate.hbm2ddl.auto 옵션)

  • DDL을 애플리케이션 실행 시점에 자동 생성 (테이블을 미리 만들 수 있다는 뜻)
  • 데이터베이스 방언을 활용하여 데이터베이스에 맞는 적절한 DDL 생성
  • 생성된 DDL은 개발 장비에서만 사용
  • DDL은 운영서버에서는 사용하지 않거나, 적절하게 다듬어서 사용한다.
  • hibernate.hbm2ddl.auto 옵션
    • create : 기존테이블 삭제 후 다시 생성(DROP + CREATE)
    • create-erop : create와 같으나 종료시점에 테이블 DROP
    • update : 변경분만 반영(운영DB에는 사용하면 안됨) 
      • 변경사항 중 있던 데이터를 지우는 것은 안된다. (추가하는 방향은 가능)
    • validate : 엔티티와 테이블이 정상 매핑되었는지만 확인
    • none : 사용하지 않음

주의할 점

  • 운영장비에는 절대 create, create-drop, update를 사용하면 안된다.
  • 개발 초기 단계에는 create 또는 update
  • 테스트 서버는 update 또는 validate
  • 스테이징과 운영 서버는 validate 또는 none

DDL 생성 기능

  • @Column 어노테이션을 통해 제약조건 등을 추가할 수 있다.
    • ex) 회원 이름은 필수, 10자 초과 X → @Column(nullable = false, length = 10)
  • DDL을 자동으로 생성할 때만 사용되는 것으로 실제 JPA 실행 로직에는 영향을 주지 않는다.

'Dev > JPA' 카테고리의 다른 글

RS) 기본키 매핑  (0) 2022.02.03
RS) 필드와 컬럼 매핑  (0) 2022.02.03
RS) 준영속 상태  (0) 2022.02.01
RS) 플러시(flush)  (0) 2022.02.01
RS) 영속성 컨텍스트  (0) 2022.02.01