Interview Question

[Interview Question] N+1 문제란 무엇이며, 어떻게 해결할 수 있나요?

sagecode 2025. 9. 2. 17:03

N+1 문제는 JPA같은 ORM에서 자주 발생하는 문제입니다.

 

한 번의 쿼리를 실행해서 엔티티 리스트를 가져온 다음 그 엔티티와 연관된 데이터를 조회하려고 접근할 때 엔티티 개수만큼 추가로 쿼리가 실행되는 문제입니다. 원래는 쿼리 한 번이면 충분한 작업이 N+1번의 쿼리로 나누어 실행되어 불필요한 DB 부하가 발생하는 것이 N+1 문제입니다.

 

ORM은 성능 이슈로 인해 기본원칙이 지연 로딩(lazy loading)입니다. 즉시 연관 엔티티를 가지고 오지 않고, 실제로 접근하는 시점에 쿼리를 날려 데이터를 조회합니다.

 

데이터 수가 많아질수록 조회 횟수가 늘어나므로 네트워크 왕복 비용, DB 부하, 메모리 사용량 등이 커져서 성능 병목이 발생합니다.

 

N+1 문제 해결방법은

JPQL에서 JOIN FETCH를 사용하여 연관된 엔티티를 한 번의 쿼리로 같이 가져옵니다. 루프 돌면서 발생하는 추가 쿼리를 없애고, 조인으로 한 번에 데이터를 불러옵니다.