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

스빈스빈별님의 프로필 이미지
스빈스빈별

작성한 질문수

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

call next value 시점이 언제인가요?

작성

·

199

0

안녕하세요! 너무 좋은 강의 잘 듣고 있습니다.
@GeneratedValue의 속성에 대한 강의를 들으면서 궁금한게 생겼는데요
@Entity
@SequenceGenerator(
        name ="MEMBER_SEQ_GENERATOR",
        sequenceName = "MEMBER_SEQ", //매핑할 데이터베이스 시퀀스 이름
        initialValue = 1, allocationSize = 50)
public class Member {
    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE,
            generator = "MEMBER_SEQ_GENERATOR")
    private Long id;

위와 같은 Member 인스턴스 52개를 for loop를 돌며 생성후 em.persist를 하려는 경우,

call next value가 한 번에 세 번 호출되는 것을 확인하였습니다.

51개 생성시에는 한 번에 두 번 호출되는 것을 강의에서도 확인했었구요.

음 저는, 코드에서, id 로 52가 필요하게 되는 경우, 그 때 call next value를 호출할 것이라 생각하였는데, 한 번에 세 개의 call next value가 호출되었다는게 이해가 되지 않습니다.

항상 이렇게 필요한 id의 번호를 먼저 파악하여 처음부터 call next value를 다 호출하고 시작하게 되나요?

답변 2

0

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

안녕하세요. 스빈스빈별님

h2 데이터베이스에서 다음 코드를 실행하신 다음에

drop sequence if exists test_memb;

create sequence test_memb start with 1 increment by 50;

시퀀스의 상태를 확인해보시면 바로 이해가 되실거에요^^

감사합니다.

0

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

안녕하세요. 스빈스빈별님

뭔가 조금 이상하네요.

기존에 만들어진 테이블의 시퀀스를 모두 삭제하고 다시 시도해보시겠어요?

DB에 있던 시퀀스를 모두 삭제하고 

for(int i=0;i<=51;i++) { //52
TestMember member = new TestMember();
member.setName("member"+i);
em.persist(member);
}

를 실행하였습니다. 

즉, JpaMain 코드는 아래와 같았습니다. 

import javax.persistence.*;

public class JpaMain {
public static <Set> void main(String[] args) {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
EntityManager em= emf.createEntityManager();
EntityTransaction tx = em.getTransaction();
tx.begin();
try {
for(int i=0;i<=51;i++) { //52
TestMember member = new TestMember();
member.setName("member"+i);
em.persist(member);
}
tx.commit();
}catch(Exception e) {
tx.rollback();
e.printStackTrace();
}finally {
emf.close();
}
emf.close();
}
}

그러자 처음부터 이런식으로 call next value가 세 번 호출이 되었습니다. 

이 때 시퀀스의 상태는 와 같았습니다 

TestMember는 

@Entity
@SequenceGenerator(
name = "TEST_MEMB_SEQ",
sequenceName ="TEST_MEMB",
initialValue = 1,
allocationSize = 50
)
public class TestMember {
@Id @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "TEST_MEMB_SEQ")
private long id;
private String name;

public long getId() {
return id;
}

public void setId(long id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}
}

스빈스빈별님의 프로필 이미지
스빈스빈별

작성한 질문수

질문하기