Java & Kotlin
spring boot N+1, EAGER, LAZY
필자A
2021. 7. 3. 23:41
jpa로 db에 데이터를 구해야하는데
테이블의 연관관계가
A(1)- B(N) 이라고 가정합니다.
URL ~/index.html를 요청을 보내는데
필요한 내용들이 A입니다. 하지만 LAZY설정을 안해주면
사용하지도 않을 값들을 들고올수가 있습니다.
@OneToMany(type = LAZY) 어노테이션을 사용하면
처음 가지올때는 LAZY속성이 붙은 필드는 PK값만 들고옵니다.(아마도?)
N+1은 B(N)의 값을 들고오는데 테이블에 값이 10개 있으면
그 수만큼 계속 SELECT를 해서 들고오는겁니다.
하지만 EAGER를 사용하면 처음 A객체를 들고올때 한번에
모두 들고 와서 후에 불필요한 조회가 줄어들게 됩니다.
반응형