call next value 시점이 언제인가요?
253
작성한 질문수 5
@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
안녕하세요. 스빈스빈별님
뭔가 조금 이상하네요.
기존에 만들어진 테이블의 시퀀스를 모두 삭제하고 다시 시도해보시겠어요?
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





