inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

공통 인터페이스 설정

외래키에 해당하는 컬럼으로 조회하고 싶을때는 어떻게 하면 될까요???

2339

dksrudwns

작성한 질문수 4

1

특정 팀 소속인 사용자 목록을 얻고 싶다면

Member Repository에서 아래와 같이 만들어서 

findByTeam(Team team, Pageable pageable);

Team 객체에 해당하는 Team의 id 값을 담아서 조회 하고 있는데 이러한 방식 맞나요??

spring JPA spring-boot java

답변 4

2

김영한

안녕하세요. dksrudwns님

findByTeam과 같이 해결하는 방법이 맞습니다.

이게 어색하면 다른 해결 방안으로는 다음과 같이 ID를 직접 조회하는 JPQL을 작성하시면 됩니다.

@Query("select m from Member m where m.team.id = :teamId")
Member findByTeamJpql(@Param("teamId") Long id);

추가로 findByTeamId(Long id) 또는 findByTeam_id(Long id)를 사용하셔도 되는데, 이 방식은 불필요한 조인이 발생합니다.(스프링 데이터의 한계)

감사합니다^^

0

김영한

네 맞습니다^^ 스프링 데이터 JPA가 findByTeamId라고 하면 Team과 강제로 조인하고 Team의 id를 찾습니다

0

alkooper5

오래됐지만 여전히 빛나는 답글에 질문을 드려봅니다.

 

혹시 어떤 한계 때문에 강제로 join이 발생하는지 알 수 있을까요?

1

김영한

안녕하세요. alkooper5님

우선 이 내용을 이해하려면 JPA 기본편 강의

섹션 11. 객체지향 쿼리 언어 - 중급 문법 -> 엔티티 직접 사용에 대해서 알아야 합니다.

 

다음과 같이 JPQL을 작성하면

select m from Member m where m.team.id = :teamId

 

다음과 같은 SQL이 실행됩니다.

select * from Member m where m.teamId = :teamId

teamId가 Member에 있기 때문에 Team과 조인이 없이 teamId를 Member에서 바로 찾을 수 있습니다.

 

스프링 데이터 JPA는 이런 경우 최적화를 하지 못하고 Team과 조인을 하는데요. 한계라기 보다는 스프링 데이터 JPA가 메서드 이름을 그대로 JPQL에 반영하는 방식으로 작동하기 때문으로 추정됩니다.

감사합니다.

1

alkooper5

빠른 답변 감사드립니다~~

0

dksrudwns

알려주시셔서 감사합니다. 

추가적으로 궁금한게 findByTeamId(Long id), findByTeam_id(Long id)으로 사용 시 (fetch = FetchType.LAZY)가 적용된 컬럼이여도 해당 방식으로 조회 시 join이 강제로 발생한다는 의미가 맞나요?? 

0

김영한

추가로 연관관계가 있을 때 id로 조회하는 것과 엔티티로 조회하는 것 관련해서 기본편 강의

섹션 11. 객체지향 쿼리 언어 - 중급 문법 -> 엔티티 직접 사용을 들어보시면 궁금해 하시는 내용을 자세히 설명해드립니다^^

감사합니다.

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

67

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

105

3

MemberRepository 구현체

0

56

1

pdf 표현 질문드립니다.

0

60

1

로그가 남지 않는 문제.

0

79

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

70

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

71

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

91

2

Sort 인터페이스는 잘 사용 안하나요?

0

52

1

스캔대상 질문드립니다.

0

45

1

하이버네이트6에서의 최적화에 이은 질문

0

82

1

save() vs saveAndFlush DB 통신 횟수

0

52

1

순수 JPA 리포지토리 코드 수정부분

0

86

2

bulk연산 후 flush하는 이유를 모르겠어요

0

150

3

bulk insert 질문입니다.

0

176

2

교만했던 것 같아요.

0

145

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

145

2

동적 테이블에 대한 질문

0

85

1

영속성 전이와 연관관계

0

130

2

강의 10:25 질문

0

73

1

단건 update 질문

0

95

2

엔티티 와 도메인의 경계

0

126

1

UsernameOnlyDto 타입 type mismatch 오류

0

119

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

136

1