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

조희제님의 프로필 이미지
조희제

작성한 질문수

실전! Querydsl

수정, 삭제 벌크 연산

update flush() 질문

작성

·

32

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]

image.png


1. 제가 생각 하는 것이 맞나요?
JPQL의 경우 실행 시 flush()가 호출 되는데
그렇다면 이전의 변경 감지 + update 쿼리가 실행이 되는 것으로 알고 있습니다.
그뒤에 flush()를 호출을 하더 라도 이전 값은 다 DB에 반영
되어 있고 영속성 컨텍스트는 변경이 없기 때문에
변경감지 쿼리도 안나가게 되는 것으로 알고 있습니다.

2. flush()를 호출 하는 것이어떤 의미가 있는 건가요?

답변 1

1

안녕하세요, 인프런 AI 인턴입니다. 조희제님!

플러시와 관련된 질문에 대해 설명 드리면서 관련 자료를 안내 드리겠습니다.

1. JPQL 및 변화 감지와 관련된 flush의 동작

JPQL 쿼리가 실행될 때 JPA는 내부적으로 flush()를 호출하여 영속성 컨텍스트와 데이터베이스를 동기화합니다. 즉, flush()가 호출되면 영속성 컨텍스트의 변경 사항이 데이터베이스에 반영되는데, 이 과정에서 변경 감지가 이루어져 update 쿼리가 생성됩니다. 이렇게 하여 데이터베이스와 영속성 컨텍스트의 일관성을 유지합니다.

2. flush()를 호출하는 이유

flush() 호출의 목적은 주로 다음과 같습니다:

  • 데이터 동기화: 변경된 엔티티들이 데이터베이스와 동기화됩니다. 이때 변경 감지가 수행되어 실제 변경된 부분에 대한 SQL 쿼리가 생성됩니다.
  • 명시적 제어: 보통 자동으로 flush()가 이루어지지만, 특정 시점에 수동으로 flush()를 호출하여 즉시 데이터베이스와 동기화가 필요할 때 사용합니다.
  • 벌크 연산 후의 일관성: 벌크 연산 후에는 영속성 컨텍스트와 데이터베이스가 불일치할 수 있으며, 이 경우 flush()를 통해 상태를 명확히 하거나 clear()를 통해 영속성 컨텍스트를 초기화하는 것이 필요합니다.

첨부하신 이미지에서 em.flush()em.clear()를 사용한 이유는 바로 영속성 컨텍스트와 데이터베이스의 상태를 일치시키고, 이후 쿼리가 수행될 때 예상치 못한 일관성 문제가 발생하지 않도록 하는 과정입니다.

관련하여 보다 심도 있는 내용을 다루고 있는 답변 링크를 첨부해드리겠습니다. 이 게시물들을 통해 플러시의 주요 개념 및 활용 방법을 더 잘 이해하실 수 있을 겁니다:

  1. “flush() 와 clear()”: 스프링 데이터 JPA의 flush 및 clear 메서드 활용과 이들의 트랜잭션 내 역할에 대해 이해하실 수 있습니다.
  2. “entityManager.flush() 호출을 하면 실제 데이터베이스에 반영이 되나요?”: flush() 호출 시 데이터베이스와의 상호작용 및 트랜잭션 커밋의 의미를 강조하는 답변입니다.
  3. “flush 질문이 있습니다.”: JPQL 실행시 flush의 자동 호출로 인한 변경 감지 및 데이터 동기화과정을 설명합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

조희제님의 프로필 이미지
조희제

작성한 질문수

질문하기