- 엔티티 매핑 소개
- 객체와 테이블 매핑 : @Entity, @Table
- 필드와 컬럼 매피 : @Column
- 기본 키 매핑 : @Id
- 연관관계 매핑 : @ManyToOne, @JoinColumn
- 1:1, 1:다, 다:다 같은 매핑
- 객체와 테이블 매핑
1. @Entity
- @Entity가 붙은 클래스는 JPA가 관리, 엔티티
- JPA를 사용해서 테이블과 매핑할 클래스는 @Entity 필수
- 주의
- 기본 생성자 필수(파라미터가 없는 public 또는 protcted 생성자)
- final 클래스, enum, interface, inner 클래스 사용 X
- 저장할 필드에 final 사용 X
※ 필드에 final을 사용할 수 없는 이유
엔티티 객체가 언제 변경되었는지 감지하기 위해 구현에서 런타임에 클래스를 하위 클래스 화하거나 클래스에 동적으로 바이트 코드를 추가하는 것이 일반적입니다. 클래스가 final로 선언되면 불가능합니다.
https://stackoverflow.com/questions/3472438/why-cant-entity-class-in-jpa-be-final/3472487
※ 데이터베이스 스키마 자동 생성
- DDL을 애플리케이션 실행 시점에 자동 생성
- 테이블 중심 -> 객체 중심
- 데이터베이스에 맞는 적절한 DDL 생성
- 생성된 DDL은 개발에서만 사용
- 주의점
- 운영장비에는 절대 create, create-drop, update 사용하면 안된다.
- 개발 초기 단계는 create 또는 update
- 테스트 서버는 update 또는 validate
- 스테이징과 운영 서버는 validate 또는 none
<!--persistence.xml-->
...
<property name="hibernate.hbm2ddl.auto" value="create" />
...
- hibernate.hbm2ddl.auto 옵션
옵션 | 설명 |
create | 기존 테이블 삭제 후 다시 생성 ( DROP+ CREATE ) |
create-drop | create와 같으나 종료시점에 테이블 DROP |
update | 변경분만 반영( 운영DB에는 사용하면 안됨 ) |
validate | 엔티티와 테이블이 정상 매핑되었는지만 확인 |
none | 사용하지 않음 |
- DDL 생성기능
- 제약조건 추가
- ex. 회원이름은 필수, 10자초가 X
- @Column(nullable = false, length = 10)
- 유니크 제약조건 추가
- @Table(uniqueConstraints = {@UniqueConstraint(name="Name_AGE_UNIQUE", columnNames={"NAME","AGE"})})
- DDL 생성 기능은 DDL을 자동 생성할 때만 사용되고, JPA의 실행 로직에는 영향을 주지 않는다.
- 컴파일 시에 자동으로 생성만 해준다.
- 런타임 시에는 영향을 주지 않는다.
- 제약조건 추가
출처
https://www.inflearn.com/course/ORM-JPA-Basic/dashboard
'JPA 프로그래밍' 카테고리의 다른 글
[자바 ORM 표준 JPA 프로그래밍] 실전 예제1 - 요구사항 분석과 기본 매핑 ( 3/3 ) (0) | 2021.07.04 |
---|---|
[자바 ORM 표준 JPA 프로그래밍] 엔티티 매핑 - 필드와 컬럼 매핑, 기본키 매핑 ( 2/3 ) (0) | 2021.06.29 |
[자바 ORM 표준 JPA 프로그래밍] 영속성 관리 (0) | 2021.06.26 |
[자바 ORM 표준 JPA 프로그래밍] Hello World 프로젝트 ( 2/2 ) (0) | 2021.06.13 |
[자바 ORM 표준 JPA 프로그래밍] Hello World 프로젝트 ( 1/2 ) (0) | 2021.06.13 |