inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

JPA @Query 로는 동적쿼리 작성은 불가능한가요?

1025

henry

작성한 질문수 9

0

QueryDSL로는 구현이 어려워, 네이티브 쿼리를 작성하려고 합니다.

그런데, where 조건을 동적으로 작성해야하는데... @Query의 경우 동적쿼리가 불가능한가요?

스프링부트 jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.
henry님, JPA에서 @Query 어노테이션을 이용한 쿼리는 기본적으로 정적 쿼리입니다. 즉, 실행 시점에 쿼리의 구조가 변경될 수 없어서 동적 쿼리를 직접 작성하는 것은 불가능합니다. 그래서 동적 쿼리가 필요한 경우는 주로 QueryDSL 같은 라이브러리를 사용하게 됩니다.

하지만, 만약 QueryDSL을 사용하기 어려운 상황이라면, @QuerynativeQuery 옵션을 사용하여 네이티브 SQL을 작성하는 방법이 있습니다. 이 경우 동적 쿼리를 직접 작성하기 위해 문자열 조합 등을 사용할 수 있지만, 이는 권장되지 않는 방법입니다. 코드의 가독성이 떨어지고 유지보수하기 어렵기 때문입니다.

대신에, 동적 쿼리의 필요성이 큰 경우에는 QueryDSL 외에도, JPA의 Criteria API를 고려해볼 수 있습니다. Criteria API는 타입 안전성을 제공하며, 복잡한 동적 쿼리를 프로그래매틱하게 구성할 수 있게 도와줍니다.

또 다른 방법으로는, 조건에 따라 분기를 나누어 여러 개의 @Query를 작성하는 것도 하나의 해결책이 될 수 있습니다. 각각의 쿼리에서 다른 WHERE 조건을 사용하여 상황에 맞는 쿼리를 선택적으로 실행할 수 있습니다.

이외에도 복잡한 동적 쿼리가 필요할 때는, 리포지토리에 사용자 정의 메소드를 구현하여 직접 EntityManager를 사용하는 방법도 있습니다. 이를 통해 JPQL 또는 네이티브 쿼리를 동적으로 생성하고 실행할 수 있습니다.

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

21

2

inheritance startegy 선택시 고려사항

0

21

1

Entity 동등성 비교

0

18

1

패키지 구분에 대해 궁금한게 있습니다

0

26

2

스프링부트 서버 에러나요

0

26

1

RepositoryTest의 패키지 위치가 domain인 이유

0

36

2

도메인 모델에서 관계와 규칙을 구분하는 방법

0

50

2

16 강의 메세지 retryCount의 의도

0

29

2

JPA Repository 질문이 있습니다!

1

38

2

페이지네이션 처리를 쿼리에서 하는 방식 질문

1

38

1

UserService, CertificationService 책임 분리 기준 질문

0

28

1

실무 조언 관련 질문입니다.

0

44

1

sdk 설정 오류

0

53

2

H2데이터베이스 파일 생성

0

56

2

SpringBoot 4.X에서의 Querydsl 설정

0

92

2

REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!

0

31

1

오탈자 - @Transactional

0

56

1

Dto와 Entity 사용 관련 질문

0

34

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

52

2

EC2 실습 중 docker-compose / docker ps 실행 시 권한 오류 문의

2

74

1

application.properties 작성 관련 질문

0

49

2

색깔구분

0

48

3

gradlew, java -jar 로 애플리케이션 실행시키기에서

1

52

1

리액트 관련 질문이 있습니다.

0

65

2