N+1 문제는 JPA같은 ORM에서 자주 발생하는 문제입니다.
한 번의 쿼리를 실행해서 엔티티 리스트를 가져온 다음 그 엔티티와 연관된 데이터를 조회하려고 접근할 때 엔티티 개수만큼 추가로 쿼리가 실행되는 문제입니다. 원래는 쿼리 한 번이면 충분한 작업이 N+1번의 쿼리로 나누어 실행되어 불필요한 DB 부하가 발생하는 것이 N+1 문제입니다.
ORM은 성능 이슈로 인해 기본원칙이 지연 로딩(lazy loading)입니다. 즉시 연관 엔티티를 가지고 오지 않고, 실제로 접근하는 시점에 쿼리를 날려 데이터를 조회합니다.
데이터 수가 많아질수록 조회 횟수가 늘어나므로 네트워크 왕복 비용, DB 부하, 메모리 사용량 등이 커져서 성능 병목이 발생합니다.
N+1 문제 해결방법은
JPQL에서 JOIN FETCH를 사용하여 연관된 엔티티를 한 번의 쿼리로 같이 가져옵니다. 루프 돌면서 발생하는 추가 쿼리를 없애고, 조인으로 한 번에 데이터를 불러옵니다.
'Interview Question' 카테고리의 다른 글
[Interview Question] 3-way handshake와 4-way handshake 과정은 무엇인가요? (0) | 2025.09.04 |
---|---|
[Interview Question] TCP와 UDP의 차이를 설명해보세요. (0) | 2025.09.02 |
[Interview Question] 트랜잭션의 ACID 특성을 설명해보세요. (0) | 2025.09.02 |
[Interview Question] INNER JOIN, LEFT JOIN 차이는 무엇인가요? (0) | 2025.09.02 |
[Interview Question] Index에 대해서 설명해보세요 (0) | 2025.09.02 |