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

Gloz0315님의 프로필 이미지
Gloz0315

작성한 질문수

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

회원 기능 테스트

강의에서 테스트 코드에서 insert 쿼리문이 발생합니다.

작성

·

247

0

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

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

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

[질문 내용]
여기에 질문 내용을 남겨주세요.

insert 쿼리문 발생.png

JUnit5 로 진행하고 강의에서 내용 그대로 작성을 하였는데, insert 쿼리문이 발생했습니다..

8:54 초 내용에서 @Transactional 어노테이션을 붙이면 자동으로 롤백해버리기 때문에 DB에 insert를 날릴 이유가 없다고 하셧는데.. 왜이러는걸까요..ㅠㅠ

 

h2 데이터베이스를 사용한 것이 아닌 mysql 데이터베이스를 연결하였지만 그거 말고 다른 설정들은 다 동일하거든요

답변 1

1

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

INSERT 쿼리를 보니, AUTO_INCREMENT를 사용하신 것 같네요.

MySQL의 경우 AUTO_INCREMENT를 사용한 키 채번을 한다면 DB에 실제 INSERT를 호출해야지만 key값을 알 수 있습니다. 이 부분에서 차이가 발생하여 쿼리가 호출된거 같아요.

추가로 다음 링크의 영한님 답변(1번)도 참고해주세요.

https://www.inflearn.com/questions/408520/identity-vs-sequence-%EC%A0%84%EB%9E%B5-%EC%A4%91-%EB%93%A0-%EC%9D%98%EB%AC%B8

감사합니다.

Gloz0315님의 프로필 이미지
Gloz0315

작성한 질문수

질문하기