PK GenerationType 선택기준 질문
516
작성한 질문수 4
JPA에서 지원되는 PK생성 전략을 네가지로 확인했습니다.
찾아보니 DB 에 따라 Oracle 이면 Sequence, MySQL 쪽이면 Identity 를 사용한다는 걸 알게 되었고, Identity 는 현재 생성된 키 값을 기준으로 증가한다는 것을 확인했습니다.
그렇다면 Sequence, Auto 그리고 Table 의 차이점이나 주로 어떻게 사용이 구분되는지 알고 싶습니다.
답변 2
0
안녕하세요, 이도원입니다.
말씀하신 내용처럼, 오라클에서는 컬럼 값의 증가를 위해 Sequence를 사용하는데, 거기에 맞춰 SEQUENCE를 사용할 수 있고, Mysql에서는 AUTO_INCREMENT 옵션으로 자동 증가 값을 사용하고, IDENTITY를 사용하시면 됩니다. IDENTITY는 DB에 자동 증가 설정을 시키는 옵션이고, SEQUENCE는 DB의 Object를 사용하여 Unique한 값을 순서대로 생성해 줄 수 있는 옵션입니다. TABLE은 키 생성을 위한 전용의 테이블을 생성하여 SEQUENCE 오브젝트처럼 사용하기 위한 옵션입니다.
GeneratedValue의 기본 설정인 AUTO는 해당 필드의 값을 얻기 위해, 이전에 사용했던 데이터를 구하기 때문에 추가적인 DB Connection이 발생됩니다. 따라서 Mysql에서는 IDENTITY를 사용하여 insert 시에는 빈 값으로 저장하고 DB에서 값을 지정하는 게 성능 면에서도 좋다고 생각됩니다.
감사합니다.
0
안녕하세요, 이도원입니다.
말씀하신 내용처럼, 오라클에서는 컬럼 값의 증가를 위해 Sequence를 사용하는데, 거기에 맞춰 SEQUENCE를 사용할 수 있고, Mysql에서는 AUTO_INCREMENT 옵션으로 자동 증가 값을 사용하고, IDENTITY를 사용하시면 됩니다. IDENTITY는 데이터베이스에 자동 증가를 시키는 옵션이고, SEQUENCE는 데이터베이스의 Unique
GeneratedValue의 기본 설정인 AUTO는 해당 필드의 값을 얻기 위해, 이전에 사용했던 데이터를 구하기 때문에 추가적인 DB Connection이 발생됩니다. 따라서 Mysql에서는 IDENTITY를 사용하여 insert 시에는 빈 값으로 저장하고 DB에서 값을 지정하는 게 성능 면에서도 좋다고 생각됩니다.
JPA
0
70
1
jpa dependency를 추가하고 SecurityConfig클래스에서 오류가 납니다.
0
84
1
웹 브라우저 400 bad request
0
83
1
@Size는 되는데 @Past는 안 됩니다.
0
76
1
pdf 자료는 없나요?
0
90
2
locale 정보가 null 이면 무조건 messages_ko.properties이 호출 되는 문제
0
98
2
Swagger 강의, Unable to infer base url 이거 뜨시는 분들 도움되시라고
0
132
1
강의에서나온 화면 피피티
0
169
1
HelloWorldBean 관련 에러
0
194
2
Swagger API 3.x 오류..
0
228
1
java: variable message not initialized in the default constructor 에러는 어찌하면 좋을까요?
1
288
1
현재 GIT에 올리신 소스를 실행해봤습니다.
0
203
2
고양이 소리가 귀엽네요 !!
0
148
2
git에서 소스받고 실습중인데
0
127
1
post가 안되요
0
113
1
한국어 같은 경우 언어코드인 messages_ko.properties 로 생성하는게 더 좋지 않나요?
0
175
2
리턴타입으로서 EntityModel<User> 와 ResponseEntity질문
0
112
1
예외처리쪽 관련 질문있습니다.
0
165
2
엔티티가 바로 응답으로 나가도 되나요??
0
239
2
안녕하세여 Cannot invoke "co.kr.joneconsulting.resfulservice.repository.PostRepository.save(Object)" because "this.postRepository" is null
0
150
2
사용자 등록하고 나서 H2 에서 보면 신규 사용자의 password, ssn 이 null 로 되어 있습니다.
0
146
2
ApplictionContext 질문
0
199
2
롬북이 안먹히는것같아요
0
161
1
인텔리제이에서스프링부트 파일 실행하면
0
244
1





