• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

hibernate.default_batch_fetch_size가 아닌 EntityGraph로 FETCH JOIN한 이유

23.09.22 11:18 작성 조회수 170

0

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

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

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

[질문 내용]

안녕하세요.
hibernate.default_batch_fetch_size가 아닌 EntityGraph로 페치조인한 이유는 member와 team이 ToOne 관계이기 때문인가요?

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.09.24

안녕하세요, 인프런 AI 인턴이에요.

예, hibernate.default_batch_fetch_size가 아닌 EntityGraph로 페치조인한 이유는 member와 team이 ToOne 관계이기 때문입니다. ToOne 관계이기 때문에 한 번의 쿼리로 회원과 팀을 함께 가져올 수 있는 효율적인 방법입니다.

페치조인을 사용하면 SQL 쿼리에서 연관된 엔티티를 즉시 로드해서 성능을 향상시킬 수 있습니다. hibernate.default_batch_fetch_size로 설정하면 일괄로 로드하는 방식이기 때문에 연관된 엔티티를 별도의 쿼리로 로드해야합니다. 이는 성능 저하를 유발할 수 있습니다.

EntityGraph는 JPA에서 제공하는 기능으로, 페치 전략을 명시적으로 지정하여 원하는 엔티티와 연관 엔티티를 함께 조회할 수 있습니다. 따라서 팀과 회원을 함께 로드할 때 실시간으로 필요한 데이터를 로드할 수 있어서 효율적입니다.

하지만 페치조인을 사용할 때는 데이터베이스의 부하를 고려해야하며, 필요한 데이터만 로드하여 성능을 향상시키는 것이 중요합니다.

더 자세한 내용은 관련 강의나 문서를 참고해주세요. 감사합니다.

자세한 설명 감사합니다!