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

염경호님의 프로필 이미지
염경호

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

JPA와 DB 설정, 동작확인

id값을 얻어오는 시점

해결된 질문

작성

·

62

0

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

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

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

[질문 내용]
ID 값은 em.persist(member)가 호출되어 엔티티가 영속성 컨텍스트에 등록되는 시점에 부여되는 것이 맞는 것인지 아니면 DB를 거쳐서 저장되면서 값이 부여되는 것인지 궁금합니다.

@PersistenceContext private EntityManager em; public Long save(Member member){ em.persist(member); return member.getId(); }

이 코드를 보면 persist(영속성 엔티티에서 관리될 때)때 id값이 정해지는 것이 맞는 것 같은데 둘 중 무엇이 맞는 개념인가요?

답변 1

1

안녕하세요. 염경호님, 공식 서포터즈 OMG입니다.

엔티티에 어떤 키 생성전략(@GeneratedValue) 옵션 값을 사용하는지에 따라 다른데요,

IDENTITY 전략은 키 생성을 DB에 위임합니다. 해당 전략에서는 INSERT쿼리가 발생해야지만, id값이 부여됩니다. MySQL이라면 AUTO_INCREMENT로 생성된 키 값이라고 보면 됩니다.

 

[JPA 기본편 - IDENTITY 전략 설명]

키 생성 시점: em.persist() 호출 -> INSERT쿼리 -> 키 생성 및 조회

image.png

 

그 외 전략(SEQUENCE, TABLE) 은영속성 컨텍스트에 등록될 때, 즉 em.persist(member) 호출 시 할당 됩니다 😀

 

[JPA 기본편 - SEQUENCE 전략 설명]

키 생성 시점: em.persist() 호출 -> SEQUENCE로 키값 할당 및 조회가능 -> 트랜잭션 커밋 시점에 INSERT쿼리 발생

 

아래 이미지에 대한 설명) 아래의 ====로 구분지은

=======

=======

출력문 사이에 출력되는 콘솔 메시지를 보면 id값이 1로 부여되고 있음을 볼 수 있습니다.

 

======

======

출력은 em.persist() 후, id값이 할당되어 있는지 확인 하는 코드이며,

System.out.println("======");
em.persist(member);
System.out.println(member.getId());
System.out.println("======");

Sequence 값을 조회하여 할당하는 것은 콘솔 내 MEMBER_SEQ라는 시퀀스에서 call next value 즉, 다음 값을 호출하여 할당해주는 과정이 진행되는 것입니다.

image.png

 

 

감사합니다.

염경호님의 프로필 이미지
염경호
질문자

아아 넵 완전히 이해되었습니다. 예전에 들었던 것이었는데 까먹었던 것 같습니다. 상세히 설명해주셔서 감사합니다!

염경호님의 프로필 이미지
염경호

작성한 질문수

질문하기