인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

신혜정님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

오라클 사용시 GeneratedValue Strategy 지정방법..

작성

·

14

0

안녕하세요

오라클과 jpa를 사용중인데요..

엔터티에서 id 지정할 때 .generatedValue.identity 옵션이 적용이 불가합니다

그래서 auto나 다른 옵션으로 주면 테이블의 아이디값이 무작위로 나오는거 같은데요

mysql처럼 1부터 순서대로 나오게 하고 싶으면 어떻게 해야 할까요?..

 

아시는 분은 답변 주시면 감사하겠습니다

 

답변 1

0

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다. 신혜정님.

오라클과 JPA를 사용할 때, @GeneratedValue(strategy=GenerationType.IDENTITY)가 MySQL에서처럼 작동하지 않는 이유는 오라클에서는 IDENTITY 전략을 기본적으로 지원하지 않기 때문입니다. 일반적으로 오라클에서는 SEQUENCE를 사용하여 이러한 문제를 해결합니다.

다음은 오라클에서 JPA의 SEQUENCE 전략을 사용하는 예입니다:

  1. 시퀀스 생성: 먼저, 오라클 데이터베이스에 시퀀스를 생성해야 합니다.

    CREATE SEQUENCE YOUR_SEQUENCE_NAME
    START WITH 1
    INCREMENT BY 1
    NOCACHE;
    
  2. 엔티티 설정: 그리고 엔티티 클래스에서 @SequenceGenerator@GeneratedValue를 사용해 시퀀스를 지정합니다.

    @Entity
    public class YourEntity {
    
    
       @Id
       @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "your_sequence_generator")
       @SequenceGenerator(name = "your_sequence_generator", sequenceName = "YOUR_SEQUENCE_NAME", allocationSize = 1)
       private Long id;
    
    
       // other fields and methods
    }
    

위와 같이 설정하면, 오라클에서도 ID를 일관적으로 순차적으로 증가시킬 수 있습니다. allocationSize를 1로 설정하면 매번 시퀀스를 호출하여 ID를 증가시키게 됩니다.

추가 정보

  • 오라클에서 IDENTITY 전략이 작동하지 않는 이유: 오라클은 기본적으로 IDENTITY를 지원하지 않으며, 이러한 이유로 직접 시퀀스를 생성 및 매핑해야 합니다.
  • allocationSize 사용: 이는 시퀀스를 미리 가져오는 수를 설정합니다. 만약 allocationSize가 50으로 설정되어 있다면, 한 번의 시퀀스 호출로 50개의 ID를 미리 가져오게 됩니다. 이 값이 1일 경우, 시퀀스는 매번 호출되어 ID를 하나씩 증가시킵니다.

관련된 질문이나 상세한 설명은 아래 질문들을 참고하실 수 있습니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.