작성
·
42
0
Optioanl<Member> findById(Long id)와
@Query("select m from Member m where m.id = :id)
Optional<Member> findByid(@Param("id") Long id)
가장 위의 코드는 spring data jpa를 이용해서 작성했기 때문에
em.flush()가 호출될 때 바로 일어나지않고
아래의 코드는 jpql로 작성했기 때문에 로직 호출 시에 바로 em.flush()가 발생하는 거 맞나요?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. kongminoo님.
많은 분들이 JPA의 flush
시점에 대해 궁금해하시는데요, 이와 관련된 내용을 설명드리겠습니다. flush
는 JPA의 영속성 컨텍스트에 있는 변경 사항을 데이터베이스로 동기화하는 작업으로, 다음과 같은 상황에서 트리거됩니다.
em.flush()
메서드가 명시적으로 호출됐을 때질문에서 살펴본 대로, Spring Data JPA
의 기본 findById
메서드는 em.find()
를 내부적으로 사용하며, 이는 flush
를 트리거하지 않습니다. 따라서 JPQL 쿼리를 작성하지 않았기 때문에 데이터베이스 flush가 즉시 발생하지 않습니다.
반면, 직접 작성한 JPQL 쿼리가 포함된 메서드는 쿼리 실행 전 flush
가 이루어집니다. JPQL은 영속성 상태를 반영한 최신의 데이터를 투명하게 보장하기 위하여 실행 전 flush
를 수행합니다.
관련 답변들을 참고하시기 바랍니다:
em.find() 자체는 flush를 트리거하지 않지만, JPQL은 트리거합니다. 이를 잘 이해하면 Spring Data JPA의 메서드 사용과 JPQL 사용 간의 flush 동작 차이를 명확히 알 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.