안녕하세요 영한님.
Spring 강의부터 JPA 강의까지 반복하고 있는 직장인입니다. 직장이 금융업종이라 단순 반복 업무 운영에 흥미를 잃어, 퇴근 후에 공부하고 있습니다.
JPA 관련 토이프로젝트를 하던 중 궁금한점이 있어 이렇게 질문드립니다. (토이프로젝트를 하다보니 영한님 강의의 많은 부분이 실제 적용되는 것을 알 수 있었습니다..^^)
1. Spring Data JPA 쿼리 메서드 관련
프로젝트에는 User, Role 테이블이 존재합니다. 관계는 다대다이지만, ManyToOne으로 각각 설계하였습니다.
여기서 특정 롤을 가지고 있지 않은 사용자이름(username)을 가져오는 쿼리를 작성하려고 하는데, 우선 JPQL로 적용해보면 아래와 같이 될 것입니다.
=> select distinct u from User u fetch join u.userRoles ur where ur.role not in ?1
그런데 영한님 강의에서도 fetch 조인 대상은 alias를 허용하지 않는다고 하셨고, 실제로 해보니 오류가 나더라고요..
근데 혹시나 해서.. Spring DataJPA 아래와 같은 쿼리 메서드를 적용해보니.. 원하는 결과를 얻을 수가 있었습니다..
=> Page<User> findDistinctUsernameByUserRolesRoleNotIn(@NotNull Pageable pageable, Collection<Role> roles);
이 경우 내부적으로 어떻게 동작한 것일까요..ㅠ?
2. 페이징 처리
위 쿼리를 페이징 처리하기 위해 BatchSize를 지정했는데요..
BatchSize와 @EntityGraph 를 같이 적용하니 동작하지 않더라고요..
제가 이해하기로는 @EntityGraph도 패치조인을 위한 전략이고, BatchSize도 패치조인 후에 페이징 범위를 가져오기 위한 방법인데, 왜 이렇게 되는지 잘 이해가 되지 않더라구요..
혹시 제가 잘 못 이해하고 있는게 있는 것일가요??
영한님 강의로 스프링에 대한 전반적 이해를 하는데 많은 도움을 얻고 있습니다. 감사합니다!