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

developer님의 프로필 이미지
developer

작성한 질문수

JPA saveAndFlush 이후 QueryDSL 조회에 관한 질문드려요.

작성

·

182

·

수정됨

0

@Transactional
public AccessTokenResponse signup(MemberRequest request) {
  Member member = request.toMember(passwordEncoder);

  MemberDetails memberDetails = memberRepository
   .findMemberDetailsByMemberId(memberRepository.saveAndFlush(member).getId())
   .orElseThrow(RuntimeException::new);
  1. 맨아래서, 2번째 줄에서 member의 정보를 DB에 저장합니다.
    : saveAndFlush 이용

  2. 그리고 나서 QueryDSL로 작성된 findMemberDetailsByMemberId 으로 해당 멤버의 정보를 조회해 왔습니다.
    : 그러나, 해당 쿼리로는 조회된 값이 없어 null 이 반환되었습니다.

 

확인해보니, saveAndFlush를 통해 해당 멤버의 정보가 즉각 DB에 반영되지 않아서 QueryDSL 로된 쿼리로 해당 멤버의 정보가 조회되지 않은 것인데요.

 

제가 알기로 saveAndFlush를 이용하면 즉각 DB에 반영되는 것으로 알고있었는데... 아닌가요?

선배님들의 조언 부탁드립니다 ㅠ

답변 1

0

안녕하세요, 인프런 AI 인턴입니다.

님의 질문에 대해 답변드리겠습니다.

saveAndFlush 메소드는 JpaRepository 인터페이스에서 제공하는 메소드입니다. 이 메소드는 엔티티를 저장하고 즉시 flush를 수행함으로써 영속성 컨텍스트의 변경 사항을 데이터베이스에 반영하도록 설계되어 있습니다. 즉, saveAndFlush 호출이 성공적으로 완료된 후에는 영속성 컨텍스트와 데이터베이스 간의 동기화가 이루어져야 합니다.

그럼에도 불구하고 조회 쿼리를 수행했을 때 결과가 없다면 몇 가지 점검해볼 필요가 있습니다.

  1. 트랜잭션이 잘못 관리되고 있는지 확인: @Transactional 어노테이션이 메소드 레벨에서 적절하게 사용되고 있는지 확인해야 합니다. 트랜잭션 경계가 잘못 설정되어 있으면 예상치 못한 동작이 발생할 수 있습니다.

  2. Flush 모드 설정 문제: EntityManager 의 flush 모드 설정이 영속성 컨텍스트의 변경 내용을 데이터베이스에 적절히 반영하지 못하고 있는지 확인합니다.

  3. 캐싱 이슈: 레벨 2 캐시가 활성화되어 있고, 캐시가 이전 상태를 반환하고 있는지 확인합니다.

  4. QueryDSL 쿼리 동작 이슈: QueryDSL 쿼리가 올바르게 작성되었는지 확인하고, 필요하다면 JPQL이나 SQL로 조회가 정상적으로 이루어지는지 테스트해 볼 수 있습니다.

영속성 컨텍스트와 데이터베이스 간의 동기화 문제가 의심된다면, 동기화 작업을 명시적으로 호출하는 방법도 있습니다. 예를 들어 EntityManager를 주입받아 flush() 메소드를 직접 호출할 수 있습니다. 이렇게 하면 영속성 컨텍스트의 변경 내용이 즉시 데이터베이스에 반영될 것입니다.

이러한 검토 후에도 문제가 해결되지 않는다면, 정확한 원인 분석을 위해 관련 로그나 추가 정보가 필요할 수 있습니다.

참고로 Spring Data JPA의 주요 문서를 확인하고자 한다면, Spring Data JPA Reference Documentation을 참조하시면 도움이 될 수 있습니다. 아래 링크도 참고하시기 바랍니다.

도움이 필요하시면 추가적인 질문을 통해 구체적인 상황을 설명해주시기 바랍니다.

developer님의 프로필 이미지
developer

작성한 질문수

질문하기