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

처리님의 프로필 이미지
처리

작성한 질문수

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

회원 기능 테스트

MemberServiceTest Rollback 관련 질문

작성

·

373

0

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

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

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

[질문 내용]
안녕하세요. 저는 롤백 false를 안해서 자동으로 rollback이 되는데 왜 insert 쿼리가 찍히는걸까요??

답변 2

3

안녕하세요!

 

현재 저장하려는 엔티티의 아이디 자동 생성 방식에 따라서 인서트 쿼리가 발생 할 수 있습니다!

 

엔티티의 아이디 자동 생성의 경우

 

  1. DB 에서 아이디에 할당할 값을 SELECT 해서 가져오거나

  2. AUTO_INCREMENT 를 이용해서 인서트 시에 값을 채워넣고

가져온 값을 실제 엔티티 객체 (위의 경우에는 Member) 에 리플렉션을 사용해서 id 값을 주입하게 되는데요

 

이 때, AUTO_INCREMENT(==GenereationType.IDENTITY) 방식을 사용하셨다면 인서트 쿼리가 발생하기 전에는 id의 값을 알 수 없습니다. 따라서 인서트 쿼리가 발생하게 됩니다.

 

 

  1. SEQUENCE 를 통해, DB에서 id 값을 SELECT 하는 경우

 

image

 

  1. IDENTITY(AUTO_INCREMENT) 방식이기 때문에 INSERT 할 시에만 id 값을 알 수 있는 경우

image

감사합니다.

 

0

안녕하세요. 처리님, 공식 서포터즈 y2gcoder입니다.

도움을 드리고 싶지만 질문 내용만으로는 답변을 드리기 어렵습니다.

실제 동작하는 전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx


주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요


추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명


링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.

처리님의 프로필 이미지
처리

작성한 질문수

질문하기