inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

@Query, 리포지토리 메소드에 쿼리 정의하기

여러테이블을 페치조인할 경우

299

3001

작성한 질문수 7

1

여러테이블을 페치조인한 정적쿼리인 경우는 @Query를 이용해서 리포지토리에서 직접 작성하고 동적쿼리만 QueryDSL사용을 권장하는 건가요?

java spring spring-boot JPA

답변 1

6

김영한

안녕하세요. weekbelt님 좋은 질문입니다.

동적쿼리는 @Query로 해결이 안되기 때문에 QueryDSL 사용을 권장합니다.

정적쿼리는 @Query를 사용해도 되고, Querydsl을 사용해도 됩니다.

정적쿼리는 제 경험상 단순한 쿼리는 @Query로 해결하고, 조금 복잡한 쿼리는 Querydsl로 처리하는게 편했습니다. 단순하다는 표현이 좀 모호하기는 한데, Querydsl은 자바 코드로 작성하기 때문에 코드를 재사용 할 수 도 있고, 컴파일 시점에 오류도 잡아주므로 장점이 많습니다. 그런데 Querydsl은 커스텀 리포지토리를 또 만들어야 하는 단점이 있습니다. 그래서 저는 한두줄에 끝나는 단순한 쿼리는 그냥 @Query로 해결하고, 조금만 복잡해지면 바로 Querydsl로 넘어갑니다.

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

146

1

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

0

146

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