🤍 전 강의 25% 할인 중 🤍

2024년 상반기를 돌아보고 하반기에도 함께 성장해요!
인프런이 준비한 25% 할인 받으러 가기 >>

  • 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

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

19.12.24 09:59 작성 조회수 204

1

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

답변 1

답변을 작성해보세요.

6

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

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

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

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

채널톡 아이콘