728x90
FetchType이란?
JPA가 하나의 Entity를 조회할 때, 연관관계에있는 객체들을 어떻게 가져올 것이냐를 나타내는 설정값
- JPA는 사용자가 직접 쿼리를 생성하지 않고, JPA에서 JPQL을 이용하여 쿼리문을 생성하여 객체와 필드를 보고 쿼리를 생성
- 다른 객체와 연관관계 매핑이 되어있으면 그 객체들까지 조회하게 되고, 이 경우 이 객체를 어떻게 불러올 것인가를 설정할 수 있음
즉시 로딩과 지연로딩
즉시 로딩: fetch = FetchType.EAGER
데이터를 조회할 때 모든 연관된 객체의 데이터까지 한꺼번에 불러온다.
지연 로딩: fetch = FetchType.LAZY
필요한 시점에 연관된 객체를 불러온다.
지연 로딩 LAZY를 사용하여 프록시로 조회
- Team의 프록시를 가져오고 추후 실제 team을 사용하는 시점에 초기화(DB 조회) 한다.
@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 = em.find(Member.class, 1L);
Team team = member.getTeam();
team.getName(); // 실제 team을 사용하는 시점에 초기화(DB 조회)
즉시 로딩 EAGER를 사용해서 함께 조회
- Member 조회시 항상 Team도 조회하여 실제 엔티티를 가져온다.
- JPA 구현체는 가능하면 조인을 사용해서 SQL 한번에 함께 조회
@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;
..
주의 사항
- 실무에서는 가급적 지연 로딩만 사용한다.
- 즉시 로딩을 적용하면 예상하지 못한 SQL이 발생한다.
- 또한 즉시 로딩은 JPQL에서 N+1 문제가 발생한다.
- @XToOne(OneToOne, ManyToOne) 관계는 기본이 즉시로딩이므로 직접 지연로딩으로 설정해야 한다.
728x90
'💻dev > 🌱Java+Spring' 카테고리의 다른 글
JPA | 기본값 타입과 임베디드 타입이란? (0) | 2023.05.01 |
---|---|
JPA | 영속성 전이(CASCADE)와 고아 객체란? (0) | 2023.05.01 |
JPA | 프록시(Proxy)란? 제대로 알고 쓰자! (0) | 2023.05.01 |
JPA | 예제로 알아보는 상속관계 매핑 (예제-4) (0) | 2023.05.01 |
JPA | 상속관계 매핑이란? @MappedSuperClass란? (0) | 2023.04.30 |