inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

영속성 컨텍스트 2

쓰기지연저장소 쿼리 저장 시점 관련 질문드립니다.

90

오리쉐리

작성한 질문수 108

0

강의 내용에서, 트랜잭션 커밋전에 em.persist나 em.remove를 하면, 영속성컨텍스트의 1차캐시에 값이 저장 또는 삭제되고, 쿼리를 생성해서 쓰기지연저장소에 저장한다고 하셨는데요.

 

트랜잭션 커밋전에 쿼리를 생성해서 쓰기지연저장소에 저장하는것인가요? 아니면 트랜잭션 커밋 이후 내부적으로 flush()호출 시 쿼리를 생성해서 쓰기지연 저장소에 저장하는것인가요??

java jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 오리쉐리님.

JPA에서의 쓰기 지연 저장소와 관련된 질문을 주셨네요. 이 개념은 JPA의 트랜잭션 관리와 깊은 연관이 있으며, 실제로 여러 궁금증을 불러일으킬 수 있는 부분입니다. 요약하여 설명드리겠습니다.

쓰기 지연 저장소는 JPA에서 영속성 컨텍스트의 한 기능으로, 기본적으로 INSERT, UPDATE, DELETE 쿼리를 트랜잭션 커밋 시점까지 모아두는 역할을 합니다. 이는 트랜잭션의 성능을 향상시키기 위한 전략입니다.

  1. em.persist()나 em.remove() 호출 시점:

    • 해당 메소드를 호출하면 영속성 컨텍스트에 엔티티가 영속 상태로 저장되거나 삭제 준비 상태가 됩니다. 이 때, 즉시 쿼리가 데이터베이스로 전송되지 않고, 쓰기 지연 저장소에 쿼리가 저장됩니다.
  2. 트랜잭션 커밋 시점:

    • 트랜잭션을 커밋할 때, JPA는 자동으로 flush()를 호출합니다. 이 과정에서 쓰기 지연 저장소에 모여 있던 쿼리들이 데이터베이스로 전송되고 실행됩니다.

따라서, 트랜잭션 커밋 전에 쿼리가 생성되어 쓰기 지연 저장소에 저장되는 것이 맞습니다. 트랜잭션 커밋 시, 즉 flush() 호출 시, 이미 저장된 쿼리들이 데이터베이스로 전달되어 실행됩니다.

추가적인 정보를 위해, 아래 링크에서 관련 질문과 답변을 확인해 보시면 더욱 도움이 되실 겁니다:

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

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

0

33

2

inheritance startegy 선택시 고려사항

0

24

1

Entity 동등성 비교

0

24

1

실무 조언 관련 질문입니다.

0

48

1

H2데이터베이스 파일 생성

0

59

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

57

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

58

1

JPQL 메소드와 락

0

56

1

Delivery @OneToOne

0

62

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

98

2

UnsupportedOperationException 발생

0

87

3

H2 Database 연결이 안됩니다.

0

98

2

연관관계 매핑 질문드립니다.

0

88

2

h2데이터베이스 실행오류

0

110

2

persistence.xml

0

112

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

83

1

영속성 컨텍스트

0

69

1

JPA 프록시

0

98

1

Native Query와 MyBatis

0

72

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

93

1

임베디드 타입 예시 코드 관련 질문

0

121

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

96

3

인텔리제이 패키지 커서 단축키 질문

0

109

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

149

1