inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! Querydsl

수정, 삭제 벌크 연산

update flush() 질문

147

조희제

작성한 질문수 16

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()를 호출 하는 것이어떤 의미가 있는 건가요?

java jpa

답변 1

1

인프런 AI 인턴

안녕하세요, 인프런 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의 자동 호출로 인한 변경 감지 및 데이터 동기화과정을 설명합니다.

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

SpringBoot 4.X에서의 Querydsl 설정

0

122

2

querydsl 오픈소스에 대한 질문

1

87

1

예제에서의 카운트 쿼리에서 join문과 where문은 필요없지 않나요?

0

118

1

Querydsl 6.X버전에 대해서 어떻게 생각하시나요?

0

336

2

여러 테이블 조인하여 통계치를 구하고자 할 때 어떤 방법이 더 효율적일까요

1

78

1

fetchResults()는 더이상 권장되지 않는다는데 맞나요?

0

168

1

querydsl sum() 메서드 없어요.

0

165

2

build 디렉터리 생성

0

147

2

자바 ORM 표준 JPA 프로그래밍 - 기본편 듣고 바로 학습해도 괜찮을까요?

0

119

2

현재 Querydsl에서 from절 서브쿼리를 지원하나요?

0

97

1

오타 제보 드립니다.

0

76

2

벌크 연산과 flush, clear

0

81

1

Run As Intellij 로 변경시 Q타입 import 불가

0

92

1

QHello import하기 문제 발생

0

152

2

등록된 함수 보는법(H2Dialect) 질문

0

73

2

5.0부터 Querydsl은 향후 fetchCount() , fetchResult() 를 지원하지 않기로 결정했다고 하는데 이에 맞는 강의

1

203

2

[환경설정 PDF 부트 3.0이후 설명 질문] build.gradle에 compileQuerydsl을 정의하지 않은 상태에서 Gradle->Tasks->other->compileQuerydsl을 클릭하라고 하는 이유가 무엇인가요??

1

207

1

querydsl 설정 문제

0

225

2

quey dsl 설정부분

0

160

2

count 쿼리 관련 질문입니다!

0

77

1

stringtemplate를 이용하여 where절 검색 방법 질문 드립니다.

0

92

1

답변부탁드리겠습니다.

0

92

2

(OrderSpecifier)관련 내용 어디있을가요

0

67

1

중급문법 벌크연산에서

0

84

2