saveAndFlush 저장후 QueryDsl 조회 문의
357
작성한 질문수 9
@Transactional
public AccessTokenResponse signup(MemberRequest request) {
Member member = request.toMember(passwordEncoder);
MemberDetails memberDetails = memberRepository
.findMemberDetailsByMemberId(memberRepository.saveAndFlush(member).getId())
.orElseThrow(RuntimeException::new);맨아래서, 2번째 줄에서 member의 정보를 DB에 저장합니다.
: saveAndFlush 이용그리고 나서 QueryDSL로 작성된 findMemberDetailsByMemberId 으로 해당 멤버의 정보를 조회해 왔습니다.
: 그러나, 해당 쿼리로는 조회된 값이 없어 null 이 반환되었습니다.
확인해보니, saveAndFlush를 통해 해당 멤버의 정보가 즉각 DB에 반영되지 않아서 QueryDSL 로된 쿼리로 해당 멤버의 정보가 조회되지 않은 것인데요.
제가 알기로 saveAndFlush를 이용하면 즉각 DB에 반영되는 것으로 알고있었는데... 아닌가요?
이런 경우 어떤 방법으로 해결할 수 있을지 조언 주시면 감사하겠습니다!
(member 정보 저장 후, querydsl로 조회해올 수 있는 방법)
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
님의 질문 내용을 바탕으로 saveAndFlush 메소드의 작동 방식에 대해 설명드리겠습니다.
saveAndFlush메소드는CrudRepository인터페이스에 정의된save메소드와 유사하게 엔티티를 저장하는 역할을 합니다. 차이점은saveAndFlush가 실행될 때 JPA의EntityManager를 이용해 즉시 DB에 반영(flush) 하도록 만듭니다. 즉, 이 메소드는 엔티티를 DB에 저장하고, 해당 세션 내에 존재하는 모든 변경 사항을 데이터베이스에 동기화하는 작업을 수행합니다.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
도움이 되셨기를 바랍니다. 추가적인 질문이 있으시면 언제든지 문의해 주세요.
inheritance startegy 선택시 고려사항
0
11
0
Entity 동등성 비교
0
14
1
패키지 구분에 대해 궁금한게 있습니다
0
20
2
스프링부트 서버 에러나요
0
22
1
RepositoryTest의 패키지 위치가 domain인 이유
0
32
2
도메인 모델에서 관계와 규칙을 구분하는 방법
0
41
2
16 강의 메세지 retryCount의 의도
0
25
2
JPA Repository 질문이 있습니다!
1
35
2
페이지네이션 처리를 쿼리에서 하는 방식 질문
1
37
1
UserService, CertificationService 책임 분리 기준 질문
0
28
1
실무 조언 관련 질문입니다.
0
41
1
sdk 설정 오류
0
50
2
H2데이터베이스 파일 생성
0
52
2
SpringBoot 4.X에서의 Querydsl 설정
0
88
2
REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!
0
30
1
오탈자 - @Transactional
0
55
1
Dto와 Entity 사용 관련 질문
0
31
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
49
2
EC2 실습 중 docker-compose / docker ps 실행 시 권한 오류 문의
2
72
1
application.properties 작성 관련 질문
0
46
2
색깔구분
0
47
3
gradlew, java -jar 로 애플리케이션 실행시키기에서
1
50
1
리액트 관련 질문이 있습니다.
0
64
2
강의 관련 외 질문입니다.
0
66
2





