inflearn logo
강의

講義

知識共有

Java ORM標準JPAプログラミング - 基本編

基本キーマッピング

GenerationType.SEQUENCE 전략

解決済みの質問

488

cauchty944495

投稿した質問数 2

2

 

그 GenerationType.SEQUENCE 전략 일때 allocationSize를 지정하면 DB에 key값(id)을 얻기위해 디비에 매번 쿼리를 날리는게 아닌 일정 개수마다 쿼리를 날리기에 최적화가 된다고 하셨고, 그 원리는 메모리를 이용하기 떄문이다라고 하셨습니다.

(질문1) 여기서 만약에 어플리케이션이 이중화가 되어있으면, 메모리를 이용한 key값(id) 설정이 조금 이상해질것 같기도한데, 이 부분에 대해서 이상이 없나요?

(질문2) 이상이 없다면, 어떻게 처리하는지 알 수 있을까요?

 

 

JPA java

回答 2

3

David

안녕하세요. 정태연님, 공식 서포터즈 David입니다.

sequence 전략을 사용하면

1. DB의 시퀀스를 일정 수치만큼 증가시키고, 증가된 범위를 가져와서 시퀀스로 사용합니다.

즉, A가 최초로 시퀀스를 가져오게 되면 1~50까지의 범위의 시퀀스를 얻게 되며, DB의 시퀀스를 50이 증가되어 그 다음 시퀀스를 얻게 된다면 51부터 얻게 될 것입니다.

2. 다른 애플리케이션에서 동일한 시퀀스를 바라보고 있고 시퀀스를 A와 동일하게 범위로 얻어간다면 51부터 얻어가게 될 것이고 1번에서 말한 것과 같이 일정 수치만큼 증가시키고 증가된 범위를 가져와서 시퀀스로 사용합니다.

각 시퀀스를 다 쓰게 된다면 다시 DB에 시퀀스(일정 범위)를 얻어 오게 될 것입니다.

감사합니다.

 

0

muscelelg

좋은 답변 덕분에 궁금증이 풀렸습니다.

좋은 답변 덕분에 하나 궁금증이 생겼는데요. 만약 A에서 1~5까지 쓰고 B에서도 51~55까지만 id로 사용했다면 6~50, 55~100은 못쓰는 영역이 되는 걸까요?

아니면 6~50+56~60을 사용하여 50만큼의 공간을 또 쓸 수 있을까요?

0

David

위 부분은 생각해본 적이 없는데, 시퀀스는 마지막 값을 기억하고 있어서 중간 값은 못 쓰지 않을까요?

0

cauchty944495

답변 감사합니다. key(id)는 데이터 구별을 위한 값이지 데이터 순서도 기억해야한다고 착각했었습니다. 답변 감사드립니다

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

0

28

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

21

1

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

0

47

1

H2데이터베이스 파일 생성

0

56

2

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

0

53

2

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

0

54

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

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

0

94

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

95

2

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

0

85

2

h2데이터베이스 실행오류

0

108

2

persistence.xml

0

108

2

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

0

80

1

영속성 컨텍스트

0

66

1

JPA 프록시

0

96

1

Native Query와 MyBatis

0

70

1

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

0

87

1

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

0

115

3

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

0

95

3

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

0

108

2

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

0

145

1