inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Trong thực tế! Sử dụng Spring Boot và JPA1 - Phát triển ứng dụng Web

Phát triển chức năng tìm kiếm đơn hàng

Specification 대비 QueryDSL의 장점이 어떤것이 있을까요?

Đã giải quyết

4533

yesjehmi

1 câu hỏi đã được viết

6

JPA를 사용한지 얼마 안되는 초보인지라 이해가 잘 되지 않아서 그러는데요..ㅜㅜ
저는 이전에 동적쿼리를 생성하기 위해 JpaSpecificationExcutor를 extends하여 조회시에 사용해왔습니다. (findAll을 하면서 인자값으로 넘겨주면 알맞는 쿼리가 생성되더라구요)
물론 queryDSL를 사용하면 더 간단히 처리되는 건 알겠으나 join이 없는 일반 원 테이블 조회에서도 specification과 같은 처리보다 queryDSL을 적용하는 것이 더 적합할지 궁금하여 질문드립니다.

java spring-boot spring 웹앱 JPA

Câu trả lời 3

10

yh

안녕하세요 햐호호님^^

개인적으로 실무에서 JpaSpecificationExcutor를 사용하는 것은 권장하지 않습니다.

JpaSpecification 자체가 결국 JPA가 제공하는 Criteria로 이루어지는데, JPA의 Criteria는 조금만 복잡해져도, 실무에서 사용이 정말 어려워 집니다. JPA를 잘 사용하는 저도 한참을 들여다 봐야 코드가 읽히더라구요.

그래서 제가 사용하는 모든 프로젝트에서는 JPA Criteria는 사용을 금지합니다. 대신에 Querydsl을 적극 활용하도록 합니다.

추가로 질문주신 join이 없는 일반 원 테이블 조회라고 해도, 결국 요구사항들어가고 프로젝트가 커지면 join도 들어가야 하고, 점점 복잡해질 확율이 매우 높습니다^^!

결론은 JPA Criteria(JpaSpecificationExecutor 포함)을 사용하지 마시고, 단순해도 다른 방법으로 푸시는 것을 권장합니다!

감사합니다^^

5

yh

네 도움이 되어드려서 기쁩니다^^

1

yesjehmi

빠르고 상세한 답변 정말 감사합니다 김영한님!

sdk 설정 오류

0

44

2

오탈자 - @Transactional

0

53

1

src/test/resources 테스트 경로 문제

0

49

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

62

1

MemberRepositoryTest 실행오류

0

73

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

182

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

136

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

50

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

71

1

기본 생성자

0

59

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

100

1

멤버서비스테스트 부분에서 막힙니다.

0

163

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

115

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

117

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

108

1

24분 27초 연관관계 편의 메서드 위치

0

112

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

106

2

빌드 툴, Gradle

0

57

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

73

2

Repository에서 EntityManager 주입 방식 차이

0

87

1

롬복과 사용자 정의 setter 메서드

0

70

1

주문 목록 조회 fetch join 질문드립니다

0

80

1

dirty checking 질문드립니다.

0

79

1

동시성 관련 질문입니다

0

72

1