inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Trong thực tế! Spring Boot và JPA Usage 2 - Phát triển API và tối ưu hóa hiệu suất

Tra cứu đơn hàng V3.1: Chuyển đổi thực thể thành DTO - Giới hạn phân trang và phá vỡ

16강 17강 간단 정리 이게 맞을까요 ?

161

dbqudgns249121

16 câu hỏi đã được viết

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]

안녕하세요. 좋은 강의 잘 수강하고 있습니다. 16강과 17강 강의가 저에게는 이해하기 어려워서 다음과 같이 정리해보았습니다. 맞게 잘 적은건지 피드백 부탁드리겠습니다 !

 

 

 

java spring spring-boot jpa

Câu trả lời 2

1

yh

안녕하세요. 병훈님

생각하신 내용이 맞습니다 🙂

감사합니다.

0

nick

도움이 되실지 모르겠지만 저도 제가 이해한 부분을 적어볼게요. 제 답변이 틀릴 수도 있다는 건 참고해주세요.

 

  1. ToOne 관계

    1. 웬만하면 패치 조인이 좋다.

    2. 조인을 해도 데이터가 증가하지 않고, 페이징 처리가 가능하기 때문이다.

    3. 그냥 조인을 걸면 LAZY 로딩에 의해 N + 1 문제가 발생할 수 있으니, 패치 조인을 해서 성능 최적화를 한다.

  2. ToMany 관계

    1. 패치 조인을 하면 LAZY와 관계없이 관련 데이터를 한번에 긁어오기 때문에 데이터 양이 정말 작다면 패치 조인을 해도 괜찮다.(쿼리가 한번만 발생하기 때문에)

    2. 컬렉션 조회에서 페이징 기법은 웬만하면 사용하면 안된다. JPA 입장에서는 DB가 조회해준 데이터 중 어떤 부분을 페이징 처리해야할 지 구분하지 못하기 때문에 조회된 데이터 모두 메모리에 적재 후 One 입장에서 페이징을 수행한다.

    3. 이때 OOM이 발생할 수 있다.

  3. 컬렉션은 지연 로딩으로 설정한다.

    1. 이후 default_batch_fetch_size 설정을 통해 설정한 size만큼 조회한다.

    2. IN 쿼리를 사용하기 때문에 데이터 수가 뻥튀기 되는 일대다 조인의 단점을 해결한다.(즉, PK를 기준으로 조건문을 사용하므로 데이터 증가 X, 조회 성능 업)

    3. 중요한 건, 애플리케이션에서 LAZY 강제 초기화(LAZY 로딩 초기화를 위해 get 메서드 호출)를 하기 때문에 "LAZY 로딩 설정 + default_batch_fetch_size" 설정을 통해 IN 쿼리가 발생할 수 있다.

    4. 즉, LAZY 강제 초기화를 하지 않으면 LAZY 초기화가 되지 않기 때문에(데이터 조회 X) IN 쿼리도 발생하지 않는다. 따라서 LAZY 강제 초기화를 하고 batch도 설정해야 한다.

 

이정도로 정리했습니다. 저도 답변을 달면서 정리가 되었네요. 혹시 틀린 점 있다면 피드백 부탁드립니다.

강의 관련 외 질문입니다.

0

62

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

0

84

1

BeanCreationException

0

86

3

Update 후 UpdateMemberResponse 매핑할 때

0

46

1

트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?

0

96

2

페이징 + 검색조건 관련해서 질문드립니다.

0

70

1

Query Dsl Q파일 질문입니다.

0

81

1

루트 쿼리라는것은

0

58

1

메서드를 분리하는 기준

0

61

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

108

3

연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략

0

83

2

fetch join과 영속화와 OSIV의 관계

0

83

2

Distinct 사용 전 결과에 대한 의문

0

112

2

레포지토리 계층에서의 트랜잭션에 대한 의문

0

55

1

영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.

0

77

2

dto 필드 속 엔티티 여부

0

58

1

뷰템플릿 사용 시

0

76

2

Result 클래스 관련 질문

0

56

1

@PostConstruct 프록시 관련 질문드립니다

0

85

1

DTO 대신 Form 사용은 안되나요?

0

133

1

OSIV ON 상태일 때

0

94

1

fetch join VS fetch join 페이징 궁금증

0

178

2

양방향 연관관계 알아보는 법?

0

102

1

데이터 초기화 시 CASCADE 옵션 궁금증

0

87

2