inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

253

스빈스빈별

작성한 질문수 5

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를 다 호출하고 시작하게 되나요?

java JPA

답변 2

0

김영한

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

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

drop sequence if exists test_memb;

create sequence test_memb start with 1 increment by 50;

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

감사합니다.

0

김영한

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

뭔가 조금 이상하네요.

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

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;
}
}

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

33

2

inheritance startegy 선택시 고려사항

0

24

1

Entity 동등성 비교

0

24

1

실무 조언 관련 질문입니다.

0

48

1

H2데이터베이스 파일 생성

0

59

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

57

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

58

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

62

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

98

2

UnsupportedOperationException 발생

0

87

3

H2 Database 연결이 안됩니다.

0

98

2

연관관계 매핑 질문드립니다.

0

88

2

h2데이터베이스 실행오류

0

110

2

persistence.xml

0

112

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

83

1

영속성 컨텍스트

0

69

1

JPA 프록시

0

98

1

Native Query와 MyBatis

0

72

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

92

1

임베디드 타입 예시 코드 관련 질문

0

121

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

96

3

인텔리제이 패키지 커서 단축키 질문

0

109

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

149

1