Spring JPA

[Spring JPA] 즉시 로딩과 지연 로딩

hoondev3 2023. 2. 2. 15:13

지연로딩

@Entity
public class Member {
 @Id @GeneratedValue
 private Long id;
 
 @Column(name = "USERNAME")
 private String name;
 
 @ManyToOne(fetch = FetchType.LAZY) //지연 로딩
 @JoinColumn(name = "TEAM_ID")
 private Team team;
 .. 
}

이 member객체를 조회할때 member의 정보만 조회하는데 team까지 조회하면 손해일 것이다.

그래서 JPA는 지연로딩을 지원한다.

 

즉 Member와 Team이 지연로딩으로 설정이 되어있으면 멤버는 팀의 프록시 개체만 조회하다가 실제 Team을 사용하는 시점에서 초기화한 후 사용한다.

 

즉시 로딩

@Entity
public class Member {
 @Id @GeneratedValue
 private Long id;
 
 @Column(name = "USERNAME")
 private String name;
 
 @ManyToOne(fetch = FetchType.EAGER) //즉시 로딩
 @JoinColumn(name = "TEAM_ID")
 private Team team;
 .. 
}

만약 Member와 Team을 자주 함께 사용하면 즉시 로딩을 사용할 수 있다.

Member를 조회할때 팀의 프록시 개체가 아니라 바로 DB에서 조회한다. 이러면 Member를 em.find()하면

member 조회 쿼리, team 조회 쿼리 2개가 동시에 나가게 된다.

 

즉시 로딩주의

  • 가급적 지연로딩만 사용(특히 실무에서)
  • 즉시 로딩을 적용하면 예상하지 못한 sql이 발생
  • jpql에서 N+1 문제를 일으킨다.
  • @ManyToOne, @OneToOne은 기본이 즉시 로딩. LAZY로 설정하자.
  • @OneToMany, @ManyToMany는 기본이 지연로딩

 

결론

모든 연관관계에 지연 로딩을 사용하자.

실무에서 즉시 로딩을 절대 사용하지 말자.
jpql fetch 조인이나, 엔티티 그래프 기능을 사용하자.

Reference

https://www.inflearn.com/course/ORM-JPA-Basic