작성
·
37
0
강의 21:06에서 작성하신대로 LAZY로 설정한 객체에 접근하면 프록시 객체가 초기화되면서 필요한 때에 DB에 쿼리를 날린다고 하셨는데요.
반복문 횟수만큼 order.getMember().getName()을 사용하니 여기서 N+1 문제가 발생하는건가요?
(LAZY 로딩의 객체를 초기화할 때는 테이블 전체를 가져오는 게 아니라 객체 하나만 로딩해오는거죠?)
감사합니다.
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. 티티티님.
당신의 질문은 LAZY 로딩과 N+1 문제에 관한 것입니다. LAZY 로딩은 연관된 엔티티가 실제로 사용될 때까지 DB에서 데이터를 가져오지 않는 기법입니다. 이를 통해 초기 로딩 시의 불필요한 데이터 로딩을 방지할 수 있습니다. 하지만 반복문 내에서 여러 번 연관된 엔티티를 호출하게 될 경우, 필요한 만큼의 쿼리가 실행되어 N+1 문제가 발생할 수 있습니다.
이 문제는 일반적으로 fetch join
이나 @EntityGraph
등을 사용하여 해결할 수 있습니다. LAZY 로딩이 걸린 해당 연관관계를 지연 로딩이 아닌 즉시 로딩으로 변경하여 한 번의 쿼리로 데이터를 가져올 수 있도록 최적화할 수도 있습니다.
관련 질문 URL에서 N+1 문제와 해결 방법에 대한 추가적인 설명을 참고하시면 도움이 될 것입니다:
- N+1의 문제와 LAZY, EAGER - 즉시 로딩과 지연 로딩에 대한 차이와 N+1 문제의 발생과 해결 방법에 대해 자세히 설명하고 있습니다.
추가적으로, 지연 로딩의 프록시 객체 초기화는 객체의 존재를 디비에서 확인하고 나서야 이루어지므로, 연관 객체 하나만 로딩됩니다. 전체를 다 가져오는 것이 아니라 필요한 시점에 필요한 객체 하나만을 초기화하게 되어 데이터 효율성을 높이는 데 기여합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.