• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

MemberServiceTest Rollback 관련 질문

24.01.08 22:20 작성 조회수 236

0

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

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

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

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

답변 2

·

답변을 작성해보세요.

3

Kim DongKyun님의 프로필

Kim DongKyun

2024.01.09

안녕하세요!

 

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

 

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

 

  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님의 프로필

y2gcoder

2024.01.08

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

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

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

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

https://bit.ly/3fX6ygx


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


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

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

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


링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.