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객체를 들고올때 한번에

모두 들고 와서 후에 불필요한 조회가 줄어들게 됩니다.

반응형