inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

saveAndFlush 저장후 QueryDsl 조회 문의

360

henry

작성한 질문수 9

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에 반영되는 것으로 알고있었는데... 아닌가요?

이런 경우 어떤 방법으로 해결할 수 있을지 조언 주시면 감사하겠습니다!
(member 정보 저장 후, querydsl로 조회해올 수 있는 방법)

스프링부트 jpa querydsl

답변 1

0

인프런 AI 인턴

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

님의 질문 내용을 바탕으로 saveAndFlush 메소드의 작동 방식에 대해 설명드리겠습니다.

  1. saveAndFlush 메소드는 CrudRepository 인터페이스에 정의된 save 메소드와 유사하게 엔티티를 저장하는 역할을 합니다. 차이점은 saveAndFlush가 실행될 때 JPA의 EntityManager를 이용해 즉시 DB에 반영(flush) 하도록 만듭니다. 즉, 이 메소드는 엔티티를 DB에 저장하고, 해당 세션 내에 존재하는 모든 변경 사항을 데이터베이스에 동기화하는 작업을 수행합니다.

  2. saveAndFlush 호출 이후 QueryDSL를 사용한 조회에서 null을 반환 받는 경우, 다음과 같은 원인을 고려할 수 있습니다:

    • 트랜잭션 범위 설정이 잘못되어 있을 수 있습니다. 해당 메소드가 실행되는 동안에는 하나의 트랜잭션 범위 안에 있어야 합니다.
    • 데이터베이스의 transaction isolation level에 따라 즉시 반영된 변경 사항이 조회되지 않을 수 있습니다. 보다 낮은 isolation level에서는 ‘dirty read’가 발생하지 않습니다.
    • JPA 구현체나 JPA Provider, 데이터베이스의 잠금 메커니즘이 원인일 수 있으므로, 이들의 설정을 확인해볼 필요가 있습니다.

이 경우 해결 방법으로, 먼저 메소드가 알맞은 트랜잭션 범위에서 실행되는지 확인하십시오. 그리고 트랜잭션 isolation level을 적절히 설정하거나 JPA의 구현체 및 데이터베이스 설정에 문제가 없는지 검토합니다.

더 자세한 내용이 필요하시면 Spring Data JPA 문서의 ‘Persisting Entities’ 섹션과 ‘Transactional query methods’ 섹션을 참조하시면 도움이 될 것입니다.

Persisting Entities 문서 원문:
https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#jpa.entity-persistence

Transactional query methods 문서 원문:
https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#transactional-query-methods

도움이 되셨기를 바랍니다. 추가적인 질문이 있으시면 언제든지 문의해 주세요.

안녕하세요 치킨 디도스 이벤트 보고 흉내내보려 들어왔습니다..

0

25

2

join에대해 질문드립니다.

0

22

1

코드 질문

0

26

1

To-Do App

0

27

1

twitterdb 연결이 안돼요

1

30

2

@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.

0

33

2

changeTeam 메서드 질문

0

35

1

테스트 관련 질문!

0

57

2

안녕하세요 질문있습니다.

0

46

2

application.properties가 적용되지 않아요

1

71

3

새 프로젝트 속 제너레이터에 SpringBoot가 없습니다.

0

54

2

설정 정보 없이 임베디드 데이터베이스 생성

0

41

1

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

42

1

N+1 관련해서 질문있습니다.

0

97

3

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

56

2

inheritance startegy 선택시 고려사항

0

41

1

Entity 동등성 비교

0

46

1

패키지 구분에 대해 궁금한게 있습니다

0

51

2

스프링부트 서버 에러나요

0

37

1

RepositoryTest의 패키지 위치가 domain인 이유

0

60

2

도메인 모델에서 관계와 규칙을 구분하는 방법

0

87

2

16 강의 메세지 retryCount의 의도

0

46

2

JPA Repository 질문이 있습니다!

1

58

2

페이지네이션 처리를 쿼리에서 하는 방식 질문

1

50

1