SEQUENCE전략 궁금한게 있습니다!
216
작성한 질문수 8
안녕하세요.
궁금한점이 SEQUNCE전략에서
@GeneratedValue(strategy = GenerationType.SEQUENCE)를 써서
하이버네이트가 제공하는 기본 시퀀스를 쓰고
그리고 테이블마다 시퀀스를 따로 관리하기위해
@SequenceGenerator를 쓰라고 하셨는데
궁금한점이 테이블마다 시퀀스를 따로 둬서 관리하는 이유가 무엇인지 궁금합니다.
항상 감사드립니다.
답변 2
0
안녕하세요. gmlwjd4667님, 공식 서포터즈 OMG입니다.
테이블마다 시쿼스를 따로 둬서 관리하지 않을 경우 다음과 같은 상황이 발생하게 됩니다.
예를 들어, ITEM 테이블과 MEMBER 테이블이 있을 때
MEMBER 데이터 하나가 생성되면 해당 데이터의 id는 시퀀스의 1을 부여받습니다.
이후 ITEM 1개가 등록되면 처음 등록한 item이지만 시퀀스가 공유되어 id가 2가 됩니다.
이러한 상황이 발생되면 id의 증가가 예측 불가능하게 증가가 되어 기본 키로 지정한 id가 누락이 된 것 인지 판별이 힘들고, 하나의 시퀀스를 공유하기 때문에 값 크기가 기하급수적으로 커질 수 있습니다.
감사합니다.
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
54
2
inheritance startegy 선택시 고려사항
0
35
1
Entity 동등성 비교
0
37
1
실무 조언 관련 질문입니다.
0
64
1
H2데이터베이스 파일 생성
0
75
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
66
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
62
1
JPQL 메소드와 락
0
62
1
Delivery @OneToOne
0
69
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
104
2
UnsupportedOperationException 발생
0
97
3
H2 Database 연결이 안됩니다.
0
101
2
연관관계 매핑 질문드립니다.
0
93
2
h2데이터베이스 실행오류
0
114
2
persistence.xml
0
119
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
87
1
영속성 컨텍스트
0
74
1
JPA 프록시
0
105
1
Native Query와 MyBatis
0
81
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
96
1
임베디드 타입 예시 코드 관련 질문
0
125
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
100
3
인텔리제이 패키지 커서 단축키 질문
0
112
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
151
1





