Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 시큐어코딩
- inflearn
- 스프링입문
- 불친절한SQL프로그래밍
- 자바연습문제
- 인프런
- 자바공부
- 자바의정석
- 항해플러스
- 스프링 핵심원리
- 자바의정석 연습문제
- Spring
- 스프링MVC
- 이것이자바다
- 스프링 부트와 JPA
- 제네릭
- 스프링
- Java의정석
- Numpy
- 항해플러스 백엔드
- Secure Coding
- 김영한
- 분석함수
- Python
- JPA
- 서블릿
- REGEXP_SUBSTR
- 불친절한 SQL 프로그래밍
- java
- docker
Archives
- Today
- Total
Continuous Challenge
4. 엔티티 매핑 - 기본 키 매핑 본문
728x90
728x90
기본 키 매핑
어노테이션
- @Id
- @GeneratedValue
기본 키 매핑 방법
- 직접 할당 : @Id만 사용
- 자동 생성 : @GeneratedValue
- IDENTITY : 데이터베이스에 위임. MYSQL
- SEQUENCE : 데이터베이스 시퀀스 오브젝트 사용. ORACLE
. @SequenceGenerator 필요
- TABLE : 키 생성용 테이블 사용. 모든 DB에서 사용
. @TableGenerator 필요
- AUTO : 방언에 따라 자동 지정. 기본값
IDENTITY 전략
- 기본 키 생성을 데이터베이스에 위임
- 주로 MySQL, PostgreSQL, SQL Server, DB2 에서 사용
(ex. MySQL의 AUTO_INCREMENT) - JPA는 보통 트랜잭션 커밋 시점에 INSERT SQL 실행
- AUTO_INCREMENT 는 데이터베이스에 INSERT SQL을 실행한 이후에 ID 값을 알 수 있음
- IDENTITY 전략은 em.persist() 시점에 즉시 INSERT SQL 실행하고 DB에서 식별자를 조회
SEQUENCE 전략
- 데이터베이스 시퀀스는 유일한 값을 순서대로 생성하는 특별한 데이터베이스 오브젝트
@SequenceGenerator
- name : 식별자 생성기 이름 (필수)
- sequenceName : 데이터베이스에 등록되어있는 시퀀스 이름 (default : hibernate_sequence)
- initialValue : DDL 생성 시에만 사용됨. 시퀀스 DDL을 생성할 때 처음 1 시작하는 수를 지정한다. (default : 1)
- allocationSize : 시퀀스 한 번 호출에 증가하는 수 (성능 최적화에 사용됨) (default : 50)
- 데이터베이스 시퀀스 값이 하나씩 증가하도록 설정되어 있으면 이 값을 반드시 1로 설정해야 한다. - catalog, schema : 데이터베이스 catalog, schema 이름
TABLE 전략
- 키 생성 전용 테이블을 하나 만들어서 데이터베이스 시퀀스를 흉내내는 전략
- 장점 : 모든 데이터베이스에 적용 가능
- 단점 : 성능
@TableGenerator
- name : 식별자 생성기 이름 (필수)
- table : 키생성 테이블명 (default : hibernate_sequences)
- pkColumnName : 시퀀스 컬럼명 (default : sequence_name)
- valueColumnNa : 시퀀스 값 컬럼명 (default : next_val)
- pkColumnValue : 키로 사용할 값 이름 (default : 엔티티 이름)
- initialValue : 초기 값, 마지막으로 생성된 값이 기준이다. (default : 0)
- allocationSize : 시퀀스 한 번 호출에 증가하는 수 (성능 최적화에 사용됨) (default : 50)
- catalog, schema : 데이터베이스 catalog, schema 이름
- uniqueConstraints(DDL) : 유니크 제약 조건을 지정할 수 있다.
권장하는 식별자 전략
- 기본 키 제약 조건 : null 아님. 유일. 변하면 안 된다.
- 미래까지 이 조건을 만족하는 자연키는 찾기 어렵다. 대리키(대체키)를 사용하자.
- 예를 들어 주민등록번호도 기본 키로 적절하지 않다.
- 권장 : Long형 + 대체키 + 키 생성전략 사용
728x90
728x90
'Spring > 자바 ORM 표준 JPA 프로그래밍 - 기본편' 카테고리의 다른 글
6. 다양한 연관관계 매핑 (0) | 2022.04.04 |
---|---|
5. 연관관계 매핑 (0) | 2022.03.29 |
4. 엔티티 매핑 - 필드와 컬럼 매핑 (0) | 2022.03.25 |
4. 엔티티 매핑 - 객체와 테이블 매핑 (0) | 2022.03.25 |
3. 영속성 관리 - 내부 동작 방식 (0) | 2022.03.24 |
Comments