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 이름 |
참고
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 |