인프런 커뮤니티 질문&답변

축구하는야채볶음밥님의 프로필 이미지

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

JPA

기본키에 대해서

작성

·

153

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
안녕하세요 8:29강의 부분에서 id를 @GenerateValue를 쓰고, 테이블에서도 generateValue를 쓰는데 대신에 auto_increment를 써도 될까요? 안되는 이유가 있을까요? 쓸 수 있다면 어노테이션 @generatedValue대신 어떤 걸 쓸 수 있나요?

답변 1

0

안녕하세요. 축구하는야채볶음밥님, 공식 서포터즈 OMG입니다.

image질문에 남기신 8분 29초 화면의 코드를 기반으로 설명드리겠습니다.

 

id를 @GenerateValue를 쓰고, 테이블에서도 generateValue를 쓰는데 대신에 auto_increment를 써도 될까요?

id 멤버변수에 @GeneratedValue를 사용한건 맞지만 테이블에서도 generateValue를 쓴다고 하신 설명이 이해가 가지 않습니다. 어떤걸 보고 generateValue라고 하신걸까요?

@GeneratedValue(strategy = GenerationType.IDENTITY) 을 설명드리면 GeneratedValue어노테이션에서 strategy 를 IDENTITY로 지정하면 키생성전략을 DB에 위임하여 AUTO_INCREMENT와 동일한 동작을 하게끔 지정하는 어노테이션입니다.

 

테이블에서도 generateValue를 쓰는데 대신에 auto_increment를 써도 될까요?

테이블에서도 generateValue라는 것을 쓴다고 하셨는데 어떤 것인지 잘 모르겠습니다. IDENTITY로 지정할 경우 MEMBER테이블은 AUTO_INCREMENT를 기반으로 기본키가 생성됩니다.

 

쓸 수 있다면 어노테이션 @generatedValue대신 어떤 걸 쓸 수 있나요?

@GeneratedValue(strategy = GenerationType.IDENTITY)

을 사용하시면 됩니다.

영한님의 JPA프로그래밍에서 발췌한 IDENTITY 관련 설명을 참고해주세요.

image

감사합니다.