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

저주받은늑대님의 프로필 이미지

작성한 질문수

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

기본 키 매핑

allocationSize 변경 오류

작성

·

523

·

수정됨

0

안녕하세요.
다름이 아니라..

로그 확인시에는 hibernate 실행때마다

이전의 table과 sequence들은 drop하는 것으로 생각하고 있었는데 (ddlauto는 create입니다)

allocationSize=1로 한 번 실행하고

allocationSize=50으로 변경하여 실행하면

The increment size of the [member_seq] sequence is set to [50] in the entity mapping while the associated database sequence increment size is [1].

라는 에러가 발생합니다.
재실행 시점에 설정된 같은 이름의 sequence도 drop하는 것이 아닌지요..?

혹은 제가 어떤 설정을 잘못 건드린걸까욥..?

(강의에서는 1에서 50으로 변경만 하여 실행하셨는데 해당 에러가 발생하지 않은것 같아 여쭙습니다!)

답변 3

0

시퀀스가 한번 생성되어있는 상태에서는 저도 안되서 member_seq 를 먼저 삭제하시고, ddl auto를 create로 두시고 다시 생성하시면 강의처럼 됩니다.

테스트해보니 allocationSize를 50에서 1로 낮추는건 되는데 거꾸로 50으로 올릴때는 Could not instantiate id generator(id제너레이터가 인스턴스화 할수없다)가 뜨면서 안됩니다.

저도 drop sequence가 실행될줄 알았는데 왜 에러가 나는지는 정확히 모르겠네요.

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 저주받은늑대님

도움을 드리고 싶지만 질문 내용만으로는 답변을 드리기 어렵습니다.

설치한 H2 데이터베이스의 정확한 버전을 알려주세요.

추가로 실제 동작하는 전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx


주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

 

추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명

 

링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.

0

안녕하세요, 인프런 AI 인턴입니다.

강의 수강생님께서 마주하신 allocationSize 변경 후 발생하는 오류는 하이버네이트 설정과 데이터베이스에 존재하는 시퀀스의 증분 크기가 불일치할 때 발생하는 일반적인 문제입니다. 이 경우, 강의 자료 도중에 allocationSize를 변경하셨을 때 기존에 생성된 시퀀스의 증분 크기와 JPA 엔티티에 설정한 allocationSize의 값이 일치하지 않아 발생하는 것으로 보입니다.

참고하실 수 있는 유사한 질문의 답변으로는 다음과 같은 게시물이 있습니다:

해당 문제를 해결하기 위해서는 존재하는 데이터베이스의 시퀀스를 직접 삭제하고 (DROP SEQUENCE) JPA 설정이나 애플리케이션이 요구하는 대로 시퀀스를 다시 생성해야 합니다. 또한 hibernate.hbm2ddl.auto 설정으로 인해 시퀀스를 자동 생성하는 경우, 시퀀스가 제대로 삭제되지 않아 문제가 발생할 수도 있는데, 이는 하이버네이트의 버그 혹은 예상하지 못한 동작일 수 있습니다.

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