데이터베이스 스키마 자동 생성
** 주의 : 운영에선 사용하면 안된다.
- DDL을 애플리케이션 실행 시점에 자동 생성
- 테이블 중싱 - > 객체 중심
- 데이터베이스 방언을 활용해서 데이터베이스에 맞는 적절한 DDL 생성
- 이렇게 생성된 DDL은 개발 장비에서만 사용
- 생성된 DDL은 운영서버에서는 사용하지 않거나, 적절히 다듬은 후 사용
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.2"
xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_2.xsd">
<persistence-unit name="hello">
<properties>
<!-- 필수 속성 -->
<property name="javax.persistence.jdbc.driver" value="org.h2.Driver"/>
<property name="javax.persistence.jdbc.user" value="sa"/>
<property name="javax.persistence.jdbc.password" value=""/>
<property name="javax.persistence.jdbc.url" value="jdbc:h2:tcp://localhost/~/test"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect"/>
<!-- 옵션 -->
<property name="hibernate.show_sql" value="true"/>
<property name="hibernate.format_sql" value="true"/>
<property name="hibernate.use_sql_comments" value="true"/>
<!-- <property name="hibernate.jdbc.batch_size" value="10"/> 10개까지 sql을 모아서 커밋 함-->
<property name="hibernate.hbm2ddl.auto" value="create" /> <!--어플리케이션 구동 시 ddl 자동 생성-->
</properties>
</persistence-unit>
</persistence>
persistence.xml 안에 다음 내용을 추가한다.
<property name="hibernate.hbm2ddl.auto" value="create" /> <!--어플리케이션 구동 시 ddl 자동 생성-->
기동 시에 로그확인 (현재 member 클래스만 있다)
Hibernate:
drop table member if exists
Hibernate:
create table member (
id bigint not null,
name varchar(255),
primary key (id)
)
drop을 날린 후 create가 된다.
- hibernate.hbm2ddl.auto 속성
ㄴ create : 기존테이블 삭제 후 다시 생성 (DROP + CREATE)
ㄴ create-drop : create와 같으나 종료시점에 테이블 DROP
ㄴ update : 변경분만 반영 (운영DB에는 사용하면 안됨) (컬럼을 지운 경우에는 alter가 날아가지 않는다.)
ㄴ validate : 엔티티와 테이블이 정상 매핑되었는지만 확인
ㄴ none : 사용하지 않음
주의점
- 운영 장비에는 절대 create, create-drop, update를 사용하면 안된다.
- 개발 초기 단계는 create 또는 update
- 테스트 서버는 update 또는 validate
- 스테이징과 운영 서버는 validate 또는 none
DDL 생성 기능
- 제약조건 추가 : 회원 이름은 필수, 10자 초과 X
ㄴ @Column (unique = true, nullable = false, length = 10) : 데이터베이스 생성 때에만 발동하므로 어플리케이션 영향이 아님
- 유니크 제약조건 추가
ㄴ @Table(uniqueConstraints = {@UniqueConstraint(name = "NAME_AGE_UNIQUE", columnNames = {"NAME","AGE"})})
- DDL생성 기능은 DDL을 자동 생성할 때만 사용되고 JPA의 실행 로직에는 영향을 주지 않는다.