• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

PK GenerationType 선택기준 질문

21.06.29 03:16 작성 조회수 308

0

@GeneratedValue(strategy = GenerationType.SEQUENCE)
@GeneratedValue(strategy = GenerationType.IDENTITY)
@GeneratedValue(strategy = GenerationType.AUTO)
@GeneratedValue(strategy = GenerationType.TABLE)

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에서 값을 지정하는 게 성능 면에서도 좋다고 생각됩니다. 

Jack님의 프로필

Jack

질문자

2021.07.03

아.. AUTO는 Select를 한번 더 해서 이전 데이터를 확인하는 군요. 답변 감사합니다