프레임워크(Framework)/JPA

[JPA] 데이터베이스 스키마 자동 생성

잇트루 2022. 12. 1. 02:13
반응형
본 내용은 온라인 강의 사이트 인프런의 김영한 님의 강의 내용이 포함되어 있습니다.
'자바 ORM 표준 JPA 프로그래밍 - 기본편'
 

자바 ORM 표준 JPA 프로그래밍 - 기본편 - 인프런 | 강의

JPA를 처음 접하거나, 실무에서 JPA를 사용하지만 기본 이론이 부족하신 분들이 JPA의 기본 이론을 탄탄하게 학습해서 초보자도 실무에서 자신있게 JPA를 사용할 수 있습니다., - 강의 소개 | 인프런

www.inflearn.com

 

데이터베이스 스키마 자동 생성

JPA는 DDL을 애플리케이션 실행 시점에 자동으로 생성하여 사용할 수 있다.

데이터베이스 방언을 활용하여 데이터베이스에 맞는 적절한 DDL을 생성하게 된다.

자동으로 생성된 DDL은 개발 단계에서만 사용하고 실제 운영할 때에는 사용하지 않거나 적절히 다듬은 후 사용해야 한다.

 

데이터베이스 방언

데이터베이스 방언은 데이터 타입, 함수명, 페이징 처리 등 각각의 데이터베이스가 제공하는 기능들을 말한다.

애플리케이션이 특정 데이터베이스에 종속되는 기능을 많이 사용할 경우 다른 데이터베이스로 교체하기가 어려워진다.

이러한 문제를 해결하기 위해 제공하는 것이 방언 클래스이다.

  • H2 : org.hibernate.dialect.H2Dialect
  • MySql : org.hibernate.dialect.MySQL5InnoDBDialect

 

스키마를 자동으로 생성하는 방법

persistence.xml

<property name="hibernate.hbm2ddl.auto" value="create" />

 

application.properties

spring.jpa.hibernate.ddl-auto=create

 

application.yml

spring:
  jpa:
    hibernate:
      ddl-auto: create

 

spring.jpa.hibernate.ddl-auto 속성

  • create : 실행할 때마다 기존 테이블 삭제 후 다시 생성 (DROP + CREATE)
  • create-drop : create와 같으나 애플리케이션 종료 시점에 테이블 삭제
  • update : 엔티티 매핑 정보를 비교하여 변경된 내용만 반영
  • validate : 엔티티와 테이블이 정상적으로 매핑되었는지만 확인
  • none : 사용하지 않음

 

 

데이터베이스 스키마 자동 생성 시 주의 사항

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

 

 

DDL 생성 기능

JPA에서 데이터베이스 스키마 자동 생성을 사용하면 DDL이 생성된다.

테이블이나 컬럼의 매핑 정보에 제약조건을 추가하더라도 DDL 생성 기능은 별도로 영향을 주지 않는다.

 

제약조건 예시

회원 이름은 필수 값이고, 10자를 초과하지 못한다는 제약 조건이 있을 경우

@Column(nullable = false, length = 10)

 

데이터베이스 테이블에서 단 하나의 값만을 가질 수 있도록 유니크 제약조건을 추가할 경우

@Table(uniqueConstraints = {@UniqueConstraint( name = "NAME_AGE_UNIQUE", columnNames = {"NAME", "AGE"} )})

 

즉, DDL 생성 기능은 DDL을 자동 생성할 때만 사용되고, JPA 실행 로직에는 영향을 주지 않는다.

반응형