• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

transactional이 붙은 메서드의 마지막 쿼리는 날아가지 않는다

22.10.24 15:05 작성 조회수 117

0

@Transactioanl이 붙은 메서드의 마지막 쿼리는 날아가지 않아요

@Commit까지 추가해야 마지막쿼리가 출력이되더라구요

그 이유가뭔가요..? 마지막 쿼리까지 다 날리고 나서 롤백을 시켜야 논리적으로 맞는 것 같은데..


1. flush()메서드 호출

2. 엔티티와 스냅샷비교

3. 업데이트 쿼리 생성 후 쓰기지연 sql저장소로 보냄

4. 디비에 flush

5. 디비에 commit

4번에서 쿼리가 발생하고 5번에서 롤백이 일어나야하는거아닌가요?

답변 1

답변을 작성해보세요.

2

David님의 프로필

David

2022.10.27

안녕하세요. 김민지님, 공식 서포터즈 David입니다.

트랜잭션이 끝나면 flush를 하게 되지만 테스트 특성상 트랜잭션이 끝나면 flush 대신 rollback을 진행하는 것 같습니다.

변경감지로 인한 update 쿼리를 보고 싶으시다면 @Commit을 붙여주시거나 flush()를 메서드 종료 직전에 호출해주세요.

감사합니다.