Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 페르마 소정리
- 구현
- 분리 집합
- springdoc
- MST
- concurreny
- SCC
- MySQL
- 백트래킹
- 누적 합
- 그래프
- Meet in the middle
- kruskal
- BFS
- 투 포인터
- disjoint set
- 알고리즘
- spring boot
- BindingAdapter
- DP
- 이분 탐색
- miller-rabin
- kapt
- DFS
- 위상정렬
- 위상 정렬
- tarjan
- union-find
- Java
- Linux
Archives
- Today
- Total
목록Spring/JPA (1)
기맹기 개발 블로그
[JPA] N+1 문제 극복기
캡스톤 프로젝트를 진행하면서 다음과 같은 다대다 관계를 나타내었다. 사용자와 스터디 그룹은 다대다 관계이므로, ERD에서 중간 테이블로 표현하였다. 그런데 JPA에서 구현하다보니 다음과 같은 기존 코드에서는 1+N 문제가 발생하였다. (N+1 문제라고 보통 불리는데, 나는 1+N이 더 직관적으로 표현한다고 생각해서 앞으로 1+N이라고 표시하고자 한다.) 사용자, 그룹 엔티티 역시 다대다 관계를 표현하기 위해서 User StudyGroup으로 일대다-다대일로 연결하였다. 정상적으로 조회 결과는 반환하지만, join으로 한 번의 쿼리를 받는 의도와는 다르게 1+N 번의 쿼리가 발생한다. 1+N 문제를 해결하기 위해서 fetch 조인을 해야하는데, 이를 위해 꼭 필요하지 않은 쿼리를 작성하는게 조금 꺼려졌다...
Spring/JPA
2022. 11. 24. 14:33