@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 |