본문 바로가기
Spring

[JPA] @GeneratedValue - SEQUENCE

by diaryDev 2025. 1. 1.
728x90

SEQUENCE

- 유일한 값을 순서대로 생성하는 특별한 데이터베이스 오브젝트

  ex) Oracle, PostgreSQL, DB2, H2 에서 사용

 

- @SequenceGenerator 필요

 

- 다음과 같이 테이블 마다 시퀀스 오브젝트를 따로 관리하고 싶다면 sequenceName 속성을 추가하면 된다.

@Entity
@SequenceGenerator(
	name = “MEMBER_SEQ_GENERATOR",
	sequenceName = “MEMBER_SEQ", //매핑할 데이터베이스 시퀀스 이름
	initialValue = 1, allocationSize = 1)
public class Member {
	@Id
	@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "MEMBER_SEQ_GENERATOR")
	private Long id;

 

@SequenceGenerator 속성

속성 설명 기본값
name 식별자 생성기 이름 필수
sequenceName DB에 등록된어 있는 시쿼스 이름 hibernate_sequence
initialValue DDL 생성 시에만 사용됨
시퀀스 DDL을 생성할 때 처음 1 시작하는 수를 지정한다.
1
allocationSize 시퀀스 한 번 호출에 증가하는 수(성능 최적화에 사용됨)
DB 시쿼스 값이 하나씩 증가하도록 설정되어 있으면 이 값을 반드시 1로 설정 필요
50
catalog, schema DB catalog, schema 이름  

 

 


 

 

참고

[JPA] 기본키(PK) 매핑 방법 및 생성 전략

[JPA] 기본 키 매핑

자바 ORM 표준 JPA 프로그래밍 - 기본편

728x90

'Spring' 카테고리의 다른 글

[JPA] 연관 관계 - 1:1  (0) 2025.01.08
[JPA] @GeneratedValue - AUTO  (0) 2025.01.06
[JPA] @GeneratedValue - IDENTITY  (0) 2024.12.30
[JPA] 기본 키 매핑 방법 - @Id, @GeneratedValue  (1) 2024.12.27
[JPA] @Lob  (1) 2024.12.25