inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

주문 조회 V3: 엔티티를 DTO로 변환 - 페치 조인 최적화

컬럼조회 질문

224

Ahrisan

작성한 질문수 25

0


강의 진행후 토이프로젝트 진행중에 질문이 있어 여쭤봅니다.

제가 하고싶은 조회는

- 로그인한 멤버가 (memberId 조인)
- 소속한 팀의 (teamId 조인)
- 모든 대화방(Room)과 각 대화방에 참여한 모든 멤버(Room_member)를 조회 하고싶습니다.

public List<Room> findRoomsByTeamId(Long memberId, Long teamId) {
return em.createQuery("select distinct r from Room r" +
" join fetch r.team t" +
" join fetch r.roomMembers rm" +
" join fetch rm.member m" +
" where t.id = :teamId" +
" and m.id = :memberId"
,Room.class )
.setParameter("teamId", teamId)
.setParameter("memberId", memberId)
.getResultList();
}

조인을 이렇게 실행했는데, 문제점이 memberId가 걸려있기 때문에, 대화방에 소속된 다른 멤버가 조회가 되지않습니다. (본인만 조회됨)

memberId를 조인하지 않으면, 대화방에 소속된 멤버가 모두 나오지만

본인이 속하지 않은 대화방도 모두 조회 됩니다...


제가 생각하는 해결방안으로는 서브쿼리를 사용하는것인데,, JPA로도 가능한가요?
아니면 다른 해결 방법이 있을까요?

 
 
 
ㅁㄴㅁㄴㅇㅁㄴ

java spring-boot JPA spring

답변 1

0

김영한

안녕하세요. 김진영님

쿼리를 2번으로 나누어서 실행하거나, 네이티브 쿼리를 사용해서 서브쿼리를 사용하시면 될 것 같아요.

감사합니다.

강의 관련 외 질문입니다.

0

75

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

1

95

1

BeanCreationException

0

94

3

Update 후 UpdateMemberResponse 매핑할 때

0

53

1

트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?

0

102

2

페이징 + 검색조건 관련해서 질문드립니다.

0

74

1

Query Dsl Q파일 질문입니다.

0

86

1

루트 쿼리라는것은

0

61

1

메서드를 분리하는 기준

0

70

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

115

3

연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략

0

90

2

fetch join과 영속화와 OSIV의 관계

0

90

2

Distinct 사용 전 결과에 대한 의문

0

117

2

레포지토리 계층에서의 트랜잭션에 대한 의문

0

61

1

영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.

0

79

2

dto 필드 속 엔티티 여부

0

60

1

뷰템플릿 사용 시

0

82

2

Result 클래스 관련 질문

0

56

1

@PostConstruct 프록시 관련 질문드립니다

0

87

1

DTO 대신 Form 사용은 안되나요?

0

140

1

OSIV ON 상태일 때

0

98

1

fetch join VS fetch join 페이징 궁금증

0

189

2

양방향 연관관계 알아보는 법?

0

108

1

16강 17강 간단 정리 이게 맞을까요 ?

0

167

2